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的更多相关文章

  1. Topcoder SRM 643 Div1 250<peter_pan>

    Topcoder SRM 643 Div1 250 Problem 给一个整数N,再给一个vector<long long>v; N可以表示成若干个素数的乘积,N=p0*p1*p2*... ...

  2. Topcoder Srm 726 Div1 Hard

    Topcoder Srm 726 Div1 Hard 解题思路: 问题可以看做一个二分图,左边一个点向右边一段区间连边,匹配了左边一个点就能获得对应的权值,最大化所得到的权值的和. 然后可以证明一个结 ...

  3. topcoder srm 714 div1

    problem1 link 倒着想.每次添加一个右括号再添加一个左括号,直到还原.那么每次的右括号的选择范围为当前左括号后面的右括号减去后面已经使用的右括号. problem2 link 令$h(x) ...

  4. topcoder srm 738 div1 FindThePerfectTriangle(枚举)

    Problem Statement      You are given the ints perimeter and area. Your task is to find a triangle wi ...

  5. Topcoder SRM 602 div1题解

    打卡- Easy(250pts): 题目大意:rating2200及以上和2200以下的颜色是不一样的(我就是属于那个颜色比较菜的),有个人初始rating为X,然后每一场比赛他的rating如果增加 ...

  6. Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串

    Problem Statement      The Happy Letter game is played as follows: At the beginning, several players ...

  7. Topcoder SRM 584 DIV1 600

    思路太繁琐了 ,实在不想解释了 代码: #include<iostream> #include<cstdio> #include<string> #include& ...

  8. TopCoder SRM 605 DIV1

    604的题解还没有写出来呢.先上605的. 代码去practice房间找. 说思路. A: 贪心,对于每个类型的正值求和,如果没有正值就取最大值,按着求出的值排序,枚举选多少个类型. B: 很明显是d ...

  9. 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)其 ...

随机推荐

  1. c#如何判断字符串是否含中文

    如代码: static bool ContainChinese(string input) { string pattern = "[\u4e00-\u9fbb]"; return ...

  2. Unity shader学习之半兰伯特光照模型

    半兰伯特光照模型,为Valve公司在开发游戏<半条命>时提出的一种技术,用于解决漫反射光无法到达区域无任凭明暗变化,丢失模型细节表现的问题. 其公式如下: Cdiffuse = Cligh ...

  3. VS 统计整个项目总的代码行数

    vs如何快速统计项目总代码行数呢,如下: vs编辑 | 查找和替换 | 在文件中查找 查找选项选 选择正则表达式 ^b*[^:b#/]+.*$ 设置如下:  结果在查找结果的最后一行,如下 

  4. 2GT PULLEYS 同步齒輪 設計規格

    2GT PULLEYS 同步齒輪 設計規格 [資料來源:http://www.jigang.com.tw/zh/product_item/64] 我的20齒 2GT模型 張貼者: 陳亮宇於 上午11: ...

  5. golang学习笔记18 用go语言编写移动端sdk和app开发gomobile

    golang学习笔记18 用go语言编写移动端sdk和app开发gomobile gomobile的使用-用go语言编写移动端sdk和app开发https://blog.csdn.net/u01249 ...

  6. node.js核心技术

    一.知识结构: http模块:配置简单 的web服务,npm/cnpm工具 express框架:express中间件进行服务配置:路由:请求处理: DB服务:学习使用mysql关系型数据库: web接 ...

  7. IPERF 网络性能测试

    Iperf 是一个网络性能测试工具.Iperf可以测试最大TCP和UDP带宽性能.Iperf具有多种参数和UDP特性,可以根据需要调整.Iperf可以报告带宽,延迟抖动和数据包丢失. Iperf 参数 ...

  8. 案例:通过shell脚本实现mysql数据备份与清理

    Shell是系统的用户界面,提供了用户与内核进行交互操作的一种接口.它接收用户输入的命令并把它送入内核去执行,实际上Shell是一个命令解释器,它解释由用户输入的命令并且把它们送到内核,不仅如此,Sh ...

  9. 为什么List.add()所增加的数据都是一样的

    1. 先上代码: List<Person> list = new ArrayList<>(); Person p = new Person(); try { Class.for ...

  10. 一名3年工作经验的java程序员应该具备的职业技能

    一名3年工作经验的Java程序员应该具备的技能,这可能是Java程序员们比较关心的内容.我这里要说明一下,以下列举的内容不是都要会的东西—-但是如果你掌握得越多,最终能得到的评价.拿到的薪水势必也越高 ...