topcoder srm 305 div1
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的更多相关文章
- 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 686 div1
problem1 link 左括号和右括号较少的一种不会大于20.假设左括号少.设$f[i][mask][k]$表示处理了前$i$个字符,其中留下的字符以$k$开头($k=0$表示'(',$k=1$表 ...
- 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 ...
随机推荐
- 输出调试技巧 PRINTF()
#define PRINTF(...) \ do { \ printf( "%d:%s::",__LINE__, __FUNCTION__);\ printf(__VA_ARGS_ ...
- python-demo实例
1.turtle库与蟒蛇案例 import turtle def drawSnake(rad,angle,len,neckrad): for i in range(len): turtle.circl ...
- Vue系列之 => 列表动画
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- [转]Hive开发经验问答式总结
本文转载自:http://www.crazyant.net/1625.html 本文是自己开发Hive经验的总结,希望对大家有所帮助,有问题请留言交流. Hive开发经验思维导图 Hive开发经验总结 ...
- super和this关键字
super关键字: this关键字: 栈内存和堆内存和方法区内存分析: 其中,new出来的即对象都在堆内存区: main方法先进栈: 方法区中 [[ super_class ]]是编译器生成,代码表现 ...
- flask 使用Flask-SQLAlchemy管理数据库(连接数据库服务器、定义数据库模型、创建库和表)
使用Flask-SQLAlchemy管理数据库 扩展Flask-SQLAlchemy集成了SQLAlchemy,它简化了连接数据库服务器.管理数据库操作会话等各种工作,让Flask中的数据处理体验变得 ...
- python练习题-打印斐波拉契数列前n项
打印斐波拉契数列前n项 #encoding=utf-8 def fibs(num): result =[0,1] for i in range(num-2): result. ...
- nodejs之pm2自动重启服务
pm2 start xxx #启动服务器 pm2 list #查看运行状态 pm2 logs #查看日志 pm2 restart xxx #重启应用 pm2 stop xxx #停止应用 监听修改,并 ...
- vue生命周期图示中英文版Vue实例生命周期钩子
vue生命周期图示中英文版Vue实例生命周期钩子知乎上近日有人发起了一个 “react 是不是比 vue 牛皮,为什么?” 的问题,Vue.js 作者尤雨溪12月4日正面回应了该问题.以下是尤雨溪回复 ...
- 【JavaScript 6连载】一、关于对象(访问)
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...