topcoder srm 330 div1
problem1 link
直接模拟。
import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class Arrows { public int longestArrow(String s) {
int result=-1;
for(int i=0;i<s.length();++i) {
final char c=s.charAt(i);
if(c=='<') {
int len=1;
if(i+1<s.length()&&(s.charAt(i+1)=='-'||s.charAt(i+1)=='=')) {
++len;
for(int k=i+2;k<s.length()&&s.charAt(k)==s.charAt(i+1);++k) {
++len;
}
}
result=Math.max(result,len);
}
else if(c=='>') {
int len=1;
if(i-1>=0&&(s.charAt(i-1)=='-'||s.charAt(i-1)=='=')) {
++len;
for(int k=i-2;k>=0&&s.charAt(k)==s.charAt(i-1);--k) {
++len;
}
}
result=Math.max(result,len);
}
}
return result;
}
}
problem2 link
把词建一个树,那么对于一个节点$u$,如果$u$不是一个单词,那么$f(u)=\prod _{v\in S_{u}}f(v)$,否则$f(u)=1+\prod _{v\in S_{u}}f(v)$.$S_{u}$表示$u$的孩子集合。
import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class PrefixFreeSubsets { static class Tree {
public boolean end;
Tree[] sons=null; public Tree() {
end=false;
sons=new Tree[26];
} } static Tree head=null; public long cantPrefFreeSubsets(String[] words) {
head=new Tree();
for(String s:words) {
Tree cur=head;
for(int i=0;i<s.length();++i) {
int t=s.charAt(i)-'a';
if(cur.sons[t]==null) {
cur.sons[t]=new Tree();
}
cur=cur.sons[t];
}
cur.end=true;
}
return dfs(head);
} static long dfs(Tree cur) {
long result=1,num=0;
for(int i=0;i<26;++i) {
if(cur.sons[i]==null) {
continue;
}
result*=dfs(cur.sons[i]);
++num;
}
if(num==0) {
return 2;
}
if(cur.end) {
++result;
}
return result;
}
}
problem3 link
设$f[i]=1$ 表示先手赢,$f[i]=0$ 表示后手赢。由于每次拿的石子数范围是$[1,22]$,所以如果出现两个位置$p,q$,使得$f[p],f[p+1],..,f[p+21]$与$f[q],f[q+1],..,f[q+21]$完全相等,那么就形成一个循环。所以只需要暴力找到这个循环位置即可。
import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class LongLongNim { static boolean[] f=new boolean[1<<22];
static int[] g=new int[1<<22]; public int numberOfWins(int maxN,int[] moves) {
Arrays.fill(f,false);
Arrays.fill(g,-1);
f[0]=false;
int pre=0;
int start0=-1,start1=-1;
for(int i=1;i<=maxN;++i) {
boolean ok=false;
for(int j=0;j<moves.length&&i>=moves[j];++j) {
if(!f[i-moves[j]]) {
ok=true;
break;
}
}
f[i]=ok;
if(f[i]) {
pre=pre<<1|1;
}
else {
pre=pre<<1;
}
if(i>22&&(pre&(1<<22))!=0) {
pre^=1<<22;
}
if(i<22) {
continue;
}
if(g[pre]==-1) {
g[pre]=i-21;
}
else if(i-21-g[pre]>=22){
start0=g[pre];
start1=i-21;
break;
}
}
if(start0==-1) {
int result=0;
for(int i=1;i<=maxN;++i) {
if(!f[i]) {
++result;
}
}
return result;
}
int result0=0,result1=0;
for(int i=1;i<start0;++i) {
if(!f[i]) {
++result0;
}
}
for(int i=start0;i<start1;++i) {
if(!f[i]) {
++result1;
}
}
maxN-=start0-1;
result1*=maxN/(start1-start0);
maxN%=start1-start0;
for(int i=0;i<maxN;++i) {
if(!f[start0+i]) {
++result1;
}
}
result1+=result0;
return result1;
}
}
topcoder srm 330 div1的更多相关文章
- Topcoder SRM 643 Div1 250<peter_pan>
Topcoder SRM 643 Div1 250 Problem 给一个整数N,再给一个vector<long long>v; N可以表示成若干个素数的乘积,N=p0*p1*p2*... ...
- Topcoder Srm 726 Div1 Hard
Topcoder Srm 726 Div1 Hard 解题思路: 问题可以看做一个二分图,左边一个点向右边一段区间连边,匹配了左边一个点就能获得对应的权值,最大化所得到的权值的和. 然后可以证明一个结 ...
- topcoder srm 714 div1
problem1 link 倒着想.每次添加一个右括号再添加一个左括号,直到还原.那么每次的右括号的选择范围为当前左括号后面的右括号减去后面已经使用的右括号. problem2 link 令$h(x) ...
- topcoder srm 738 div1 FindThePerfectTriangle(枚举)
Problem Statement You are given the ints perimeter and area. Your task is to find a triangle wi ...
- Topcoder SRM 602 div1题解
打卡- Easy(250pts): 题目大意:rating2200及以上和2200以下的颜色是不一样的(我就是属于那个颜色比较菜的),有个人初始rating为X,然后每一场比赛他的rating如果增加 ...
- Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串
Problem Statement The Happy Letter game is played as follows: At the beginning, several players ...
- Topcoder SRM 584 DIV1 600
思路太繁琐了 ,实在不想解释了 代码: #include<iostream> #include<cstdio> #include<string> #include& ...
- TopCoder SRM 605 DIV1
604的题解还没有写出来呢.先上605的. 代码去practice房间找. 说思路. A: 贪心,对于每个类型的正值求和,如果没有正值就取最大值,按着求出的值排序,枚举选多少个类型. B: 很明显是d ...
- topcoder srm 575 div1
problem1 link 如果$k$是先手必胜那么$f(k)=1$否则$f(k)=0$ 通过对前面小的数字的计算可以发现:(1)$f(2k+1)=0$,(2)$f(2^{2k+1})=0$,(3)其 ...
随机推荐
- sqli-labs(十五)(堆叠注入)
第三十八关: 后面好几关都是堆叠注入.简单介绍下: Stacked injections:堆叠注入.从名词的含义就可以看到应该是一堆sql语句(多条)一起执行.而在真实的运用中也是这样的,我们知道在m ...
- 函数式编程语言(functional language)
内容根据百度词条整理! 转载请声明来源:https://baike.baidu.com/item/%E5%87%BD%E6%95%B0%E7%BC%96%E7%A8%8B%E8%AF%AD%E8%A8 ...
- caffe的运行create_data.sh前对VOC2007图片格式的更改
运用caffe进行深度学习之前需要对图片进行预处理,将图片的大小,格式等进行修改 将300*300的图片改为256*256格式 则将以下参数改为: min_dim=256 max_dim=256 wi ...
- 并发工具CyclicBarrier
想想一下这样一个场景,有多个人需要过河,河上有一条船,船要等待满10个人才过河,过完河后每个人又各自行动. 这里的人相当于线程,注意这里,每个线程运行到一半的时候,它就要等待一个条件,即船满过河的条件 ...
- java中的锁之AbstractQueuedSynchronizer源码分析(一)
一.AbstractQueuedSynchronizer类介绍. 该抽象类有两个内部类,分别是静态不可继承的Node类和公有的ConditionObject类.AbstractQueuedSynchr ...
- workerman 7272端口被占用
1/问题:workerman 7272端口被占用 2/策略: 1.查找被占用的端口 netstat -tln netstat -tln | grep 8083 netstat -tln 查看端口使用情 ...
- kali 创建快捷方式的方法
Kali应用程序快捷方式分析 kali默认使用Gnome桌面环境,所以给kali添加应用程序快捷方式就是给Gnome添加应用快捷方式. 在/usr/share/applications目录下有很多的. ...
- 75.Java异常处理机制-手动抛出异常
package testDate; import java.io.File; import java.io.FileNotFoundException; public class TestReadFi ...
- Symfony2 学习笔记之控制器
一个controller是你创建的一个PHP函数,它接收HTTP请求(request)并创建和返回一个HTTP回复(Response).回复对象(Response)可以是一个HTML页面,一个XML文 ...
- goldengate 12.3 实现mysql数据及DDL实时同步
以下环境在mysql 5.7上完成. set mysql_home=mysql安装路径 set path=%mysql_home%\bin;%path% 首先要准备mysql的启动,可参考:http: ...