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. 实时计算DStream下求平均值(reduceByKey or combineByKey)

    对NC市的卡口数据进行分析,大概所有卡口每15秒接入的有效数据在3000条左右,现在产品经理要求对这些数据进行拥堵分析,通过两个卡口之间的车辆行驶时长来判断道路的拥堵情况.具体算法不展开.其中我需要做 ...

  2. python入门之列表

    1.列表基本格式# list 类 列表li = [1, 2, 3, "sb", ["时间",[9, 10], "huang"], 6, 7, ...

  3. linux脚本文件执行的方法之间的区别

    sh/bash sh a.sh bash a.sh 都是打开一个subshell去读取.执行a.sh,而a.sh不需要有"执行权限",在subshell里运行的脚本里设置变量,不会 ...

  4. C#深入研究ArrayList动态数组自动扩容原理

    1 void Test1() { ArrayList arrayList = new ArrayList(); ; ; i < length; i++) { arrayList.Add(&quo ...

  5. CentOS下nginx+php的配置及nginx开机启动配置

    关闭防火墙 (不然外链接是访问不了 apache) service iptables stop 关闭安全系统 SELinux( 不然报403 访问页面错误 ) 1.Nginx安装主要在于配置文件的修改 ...

  6. spring aop:aspectj-autoproxy 配置

    经常遇到aop-aspectJ的通知不被执行的问题 解决方法:http://blog.csdn.net/qwdafedv/article/details/53005210 首先,确保配置文件都已经是正 ...

  7. C# 实现生产者消费者队列

    开发过程中经常会碰到这样的场景:需要从一个地方获取一些数据,然后处理数据并将其保存在数据库中. 1 2 3 4 5 6 7 8 9 10 private void FetchData() {} pri ...

  8. Django admin模块无法调用css样式文件

    在使用Django Admin开发时,发现admin模块css样式文件丢失,无法调用,使火狐浏览器提示: 此 URL 的资源不是文本: http://127.0.0.1:8000/statics/ad ...

  9. 使用Oozie中workflow的定时任务重跑hive数仓表的历史分期调度

    在数仓和BI系统的开发和使用过程中会经常出现需要重跑数仓中某些或一段时间内的分区数据,原因可能是:1.数据统计和计算逻辑/口径调整,2.发现之前的埋点数据收集出现错误或者埋点出现错误,3.业务数据库出 ...

  10. 初探AngularJs框架(一)

    一.需要准备的环境 Nodejs:https://nodejs.org/en/download/ Python:https://www.python.org/downloads/release/pyt ...