problem1 link

直接按照题意模拟即可。

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class UnfairDivision { public int albertsShare(int[] assets) {
final int n=assets.length;
for(int i=1;i<n;++i) {
assets[i]+=assets[i-1];
}
int result=0;
for(int i=0;i<n-1;++i) {
int betty=0,carla=0,albert=0;
for(int j=0;j<n-1;++j) {
if(j==i) {
continue;
}
int[] a=new int[3];
if(j<i) {
a[0]=assets[j];
a[1]=assets[i]-assets[j];
a[2]=assets[n-1]-assets[i];
}
else {
a[0]=assets[i];
a[1]=assets[j]-assets[i];
a[2]=assets[n-1]-assets[j];
}
Arrays.sort(a);
if(a[1]>betty||a[1]==betty&&a[2]>carla) {
carla=a[2];
betty=a[1];
albert=a[0];
}
}
result=Math.max(result,albert);
}
return result;
}
}

problem2 link

$f[a][b][c][d]$表示将第一个串的$[a,b]$以及第二个串的$[c,d]$拿出来能否拼成一个回文串。每次扩展有四种情况:

(1)第一个串两端相等,那么只需判断$f[a+1][b-1][c][d]$即可;

(2)第一个串的左侧和第二个串右侧相等,只需判断$f[a+1][b][c][d-1]$即可;

(3)第二个串的左侧和第一个串的右侧相等,只需判断$f[a][b-1][c+1][d]$即可;

(4)第二个串左右相等,那么只需判断$f[a][b][c+1][d-1]$即可。

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class InterleavePal { final static int INF=99999; int n,m;
int[][][][] f=null;
String S,T;
boolean[][] gs=null;
boolean[][] gt=null; boolean check(String s,int ll,int rr) {
while(ll<rr) {
if(s.charAt(ll)!=s.charAt(rr)) {
return false;
}
++ll;
--rr;
}
return true;
} int dfs(int l1,int r1,int l2,int r2) { if(l1>r1) {
if(l2>r2) return 0;
if(gt[l2][r2]) return r2-l2+1;
return -INF;
}
if(l2>r2) {
if(gs[l1][r1]) return r1-l1+1;
return -INF;
} if(f[l1][r1][l2][r2]!=-1) {
return f[l1][r1][l2][r2];
}
int result=-INF;
if(l1<r1&&S.charAt(l1)==S.charAt(r1)) {
result=Math.max(result,2+dfs(l1+1,r1-1,l2,r2));
}
if(S.charAt(l1)==T.charAt(r2)) {
result=Math.max(result,2+dfs(l1+1,r1,l2,r2-1));
}
if(T.charAt(l2)==S.charAt(r1)) {
result=Math.max(result,2+dfs(l1,r1-1,l2+1,r2));
}
if(l2<r2&&T.charAt(l2)==T.charAt(r2)) {
result=Math.max(result,2+dfs(l1,r1,l2+1,r2-1));
}
f[l1][r1][l2][r2]=result;
return result;
} public int longestPal(String s, String t) {
n=s.length();
m=t.length(); if(n==0&&m==0) {
return 0;
} S=s;
T=t;
f=new int[n][n][m][m]; int result=0; gs=new boolean[n][n];
for(int i=0;i<n;++i) {
for(int j=i;j<n;++j) {
if(check(S,i,j)) {
gs[i][j]=check(S,i,j);
if(gs[i][j]) {
result=Math.max(result,j-i+1);
}
}
}
}
gt=new boolean[m][m];
for(int i=0;i<m;++i) {
for(int j=i;j<m;++j) {
if(check(T,i,j)) {
gt[i][j]=check(T,i,j);
if(gt[i][j]) {
result=Math.max(result,j-i+1);
}
}
}
}
if(n==0||m==0) {
return result;
}
for(int i=0;i<n;++i) {
for(int j=i;j<n;++j) {
for(int k=0;k<m;++k) {
for(int p=k;p<m;++p) {
f[i][j][k][p]=-1;
}
}
}
}
for(int i=0;i<n;++i) {
for(int j=i;j<n;++j) {
for(int k=0;k<m;++k) {
for(int p=k;p<m;++p) {
result=Math.max(result,dfs(i,j,k,p));
}
}
}
}
return result;
}
}

problem3 link

首先,对于指数是偶数的情况来说,会产生重复,比如$x^{12}=(x^{3})^{4}=(x^{6})^{2}$。因此,只计算指数为素数时可避免这种情况;

其次,$(x^{3})^5=(x^{5})^{3}$。这种情况下,只计算指数较小者。所以在计算到指数为较大的素数时,比如11,假设最大值为$t$,即$t^{11}\leq n,(t+1)^{11}>n$.那么要判断有多少数字$u$满足$u^{k}\leq t$,其中$k<11$。

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class PowerCollector { boolean isprime(int k) {
for(int i=2;i*i<=k;++i) {
if(k%i==0) {
return false;
}
}
return true;
} long get(long a,int b,long n) {
long t=1;
for(int i=0;i<b;++i) {
if(t>n/a) {
return n+1;
}
t*=a;
}
return t;
} long getMax(long n,int k) {
long low=1,high=n;
long result=1;
while(low<=high) {
long M=(low+high)>>1;
if(get(M,k,n)>n) {
high=M-1;
}
else {
result=Math.max(result,M);
low=M+1;
}
}
return result;
} long dfs(long n,int k) {
long result=1;
for(int i=2;i<k;++i) {
if(!isprime(i)) {
continue;
}
long t=getMax(n,i);
if(t==1) {
break;
}
result+=t-dfs(t,i);
}
return result;
} public String countPowers(String N) {
long n=Long.valueOf(N);
if(n==1) {
return "1";
}
return String.valueOf(dfs(n,62));
}
}

  

topcoder srm 305 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 686 div1

    problem1 link 左括号和右括号较少的一种不会大于20.假设左括号少.设$f[i][mask][k]$表示处理了前$i$个字符,其中留下的字符以$k$开头($k=0$表示'(',$k=1$表 ...

  4. topcoder srm 714 div1

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

  5. topcoder srm 738 div1 FindThePerfectTriangle(枚举)

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

  6. Topcoder SRM 602 div1题解

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

  7. Topcoder SRM 627 div1 HappyLettersDiv1 : 字符串

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

  8. Topcoder SRM 584 DIV1 600

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

  9. TopCoder SRM 605 DIV1

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

随机推荐

  1. Linux系统安装nodejs

    参考文档 官网连接 镜像连接 安装方法有三种: 1. 源码安装(耗时) 2. apt-get / yum 安装(版本比较低) 3. 解压后创建软连接(推荐) 方法一. 1 ) 指定目录下下载源码包 $ ...

  2. css 清除一些默认的设置

    一.input标签的placeholder的设置 input::-webkit-input-placeholder{ /*WebKit browsers*/ //重置样式 } input::-moz- ...

  3. vs远程调试 转http://www.cnblogs.com/magicchaiy/archive/2013/05/28/3088274.html

    远程调试应用场景 部署环境:ASP.NET(C#)+IIS+Win7 64 bit 很多公司的开发模式都是将开发机器和服务器分开,也就是开发一台机,服务器一台机.而测试人员会在服务器上录入测试数据,此 ...

  4. sitecore系列教程之Sitecore个性化-配置文件,模式和角色

    这是利用Sitecore规则引擎实现数字化转换的三部分系列的第二部分.阅读上一篇文章,通过为您的个性化体验定义内容策略来设置基础.   Sitecore有一个非常强大的规则引擎,可以帮助推动个性化的用 ...

  5. [openjudge-动态规划]怪盗基德的滑翔翼

    题目描述 描述 怪盗基德是一个充满传奇色彩的怪盗,专门以珠宝为目标的超级盗窃犯.而他最为突出的地方,就是他每次都能逃脱中村警部的重重围堵,而这也很大程度上是多亏了他随身携带的便于操作的滑翔翼. 有一天 ...

  6. 【Scala学习之二】 Scala 集合 Trait Actor

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...

  7. 基于FPGA摄像头图像采集显示系统

    本系统主要由FPGA主控模块.图像采集模块.图像存储模块以及图像显示模块等模块组成.其中图像采集模块选择OV7670摄像头模块,完成对视频图像的采集和解码功能,并以RGB565标准输出RGB 5:6: ...

  8. ClassThree__HomeWork

    作业一 使用类的静态字段和构造函数,可以跟踪某个类所创建对象的个数.请写一个类,在任何时候都可以向它查询“你已经创建了多少个对象?”. 代码 public class TestOne {       ...

  9. selenium-java web自动化测试工具抓取百度搜索结果实例

    selenium-java web自动化测试工具抓取百度搜索结果实例 这种方式抓百度的搜索关键字结果非常容易抓长尾关键词,根据热门关键词去抓更多内容可以用抓google,百度的这种内容容易给屏蔽,用这 ...

  10. TensorFlow 1.2.0新版本完美支持Python3.6,windows在cmd中输入pip install tensorflow就能下载应用最新tensorflow

    TensorFlow 1.2.0新版本完美支持Python3.6,windows在cmd中输入pip install tensorflow就能下载应用最新tensorflow 只需在cmd中输入pip ...