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. matlab 字符串处理函数

    https://www.cnblogs.com/emanlee/archive/2012/09/13/2683912.html % 字符串处理 a='  a';b='b  b';c='cccc';m= ...

  2. sqli-labs(一)

    第一关:第一关会讲的比较详细,后面的关卡中只有特殊的地方我会单独拿出来说. 第一关是一个很简单的string类型的sql注入,并且会报错,输入参数id=',页面会报错 值得注意的是: 1.报错信息中 ...

  3. ProxySQL(读写分离)部署

    proxySQL是MySQL的中间件产品,是灵活强大的代理层,实现读写分离,支持Query路由功能,支持动态指定某个SQL进行缓存,支持动态加载配置,故障切换和一些SQL 过滤功能 环境: 192.1 ...

  4. Spring MVC / Boot

    https://stackoverflow.com/questions/5690228/spring-mvc-how-to-return-image-in-responsebody http://hw ...

  5. Nexus3.x.x上传第三方jar

    exus3.x.x上传第三方jar: 1. create repository 选择maven2(hosted),说明: proxy:即你可以设置代理,设置了代理之后,在你的nexus中找不到的依赖就 ...

  6. python os.path.join()

    >>> import os >>> path = '/Users/beazley/Data/data.csv' >>> # Get the las ...

  7. flask模板应用-自定义错误页面

    自定义错误页面 当程序返回错误响应时,会渲染一个默认的错误页面,我们可以注册错误处理函数来处理错误页面 错误处理函数和视图函数很相似,返回值将作为响应的主题,因此我们先要创建错误页面的模板文件.为了和 ...

  8. Radio中REG

    Auto REG/REG OFF在广播接收质量不好时,收音机首先仅调整到该广播电台当前发射的可选频率.但是,如果接收质量差到“该发射电台濒临消失”的程度,则收音机也会接收德国NDR1(北德意志广播电台 ...

  9. 102.自己实现ArrayList

    package collection; import java.util.ArrayList; import java.util.List; /** * 自己实现一个ArrayList,帮助理解底层结 ...

  10. [转载]String.Empty、string=”” 和null的区别

    String.Empty是string类的一个静态常量: String.Empty和string=””区别不大,因为String.Empty的内部实现是: 1 2 3 4 5 6 7 8 9 10 1 ...