problem1 link

先计算出最上面、最下面一层,根据最上面一层的数量计算答案。

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class PyramidOfCubes { public double surface(int K) {
int s=0,m=-1;
for(int i=1;;++i) {
if(s+i*i>=K) {
m=i;
break;
}
s+=i*i;
}
for(int i=m;;--i) {
if(i*i>=K) {
s=i;
break;
}
K-=i*i;
}
double result=0.0;
result+=m*m*2;
result+=(s+m)*(m-s+1)/2*4;
int row=(K+s-1)/s;
int col=K>=s?s:K;
result-=s*4-(row+col)*2;
if(s==m) {
result-=m*m*2-K*2;
}
return result;
}
}

  

problem2 link

拿一个线段树维护中位数即可。

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class FloatingMedian { static final int N=65537; static class node {
int L,R,num;
} node[] A=new node[N<<2];
int[] a=null; void build(int t,int L,int R) {
A[t]=new node();
A[t].L=L;
A[t].R=R;
A[t].num=0;
if(L==R) return;
int M=(L+R)>>1;
build(t<<1,L,M);
build(t<<1|1,M+1,R);
} void insert(int t,int p,int d) {
A[t].num+=d;
if(A[t].L==A[t].R) {
return;
} int M=(A[t].L+A[t].R)>>1; if(p<=M) {
insert(t<<1,p,d);
}
else {
insert(t<<1|1,p,d);
}
} int get(int t,int k) {
if(A[t].L==A[t].R){
return A[t].L;
}
if(A[t<<1].num>=k) {
return get(t<<1,k);
}
return get(t<<1|1,k-A[t<<1].num);
} public long sumOfMedians(int seed, int mul, int add, int n, int K) { a=new int[n+1];
a[1]=seed;
for(int i=2;i<=n;++i) {
a[i]=(int)(((long)a[i-1]*mul+add)&65535);
} build(1,0,N-1);
long result=0;
final int T=(K+1)>>1;
for(int i=1;i<=n;++i) {
insert(1,a[i],1);
if(i>=K) {
result+=get(1,T);
insert(1,a[i-K+1],-1);
}
}
return result;
}
}

problem3 link

f[S][k][t]表示已经选择的块的集合为$S$,最上面一个是第$k$块,$t$表示朝下的面的类型,有三种。

import java.util.*;
import java.math.*;
import static java.lang.Math.*; public class BoxTower { int[][][] f=null; int getheight(int[] x,int[] y,int[] z,int k,int t) {
if(t==0) {
return z[k];
}
else if(t==1) {
return y[k];
}
else {
return x[k];
}
} boolean check(int[] x,int[] y,int[] z,int k1,int t1,int k2,int t2) {
int r1=t1==2?y[k1]:x[k1];
int c1=t1==0?y[k1]:z[k1];
int r2=t2==2?y[k2]:x[k2];
int c2=t2==0?y[k2]:z[k2];
return r1>=r2&&c1>=c2||r1>=c2&&c1>=r2;
} public int tallestTower(int[] x, int[] y, int[] z) {
final int n=x.length;
f=new int[1<<n][n][3];
for(int i=0;i<(1<<n);++i) {
for(int j=0;j<n;++j) {
if((i&(1<<j))!=0) {
continue;
}
if(i==0) {
f[1<<j][j][0]=getheight(x,y,z,j,0);
f[1<<j][j][1]=getheight(x,y,z,j,1);
f[1<<j][j][2]=getheight(x,y,z,j,2);
continue;
}
for(int k=0;k<n;++k) {
if((i&(1<<k))==0) {
continue;
}
for(int t1=0;t1<3;++t1) {
for(int t2=0;t2<3;++t2) {
if(check(x,y,z,k,t1,j,t2)) {
int t=f[i][k][t1]+getheight(x,y,z,j,t2);
f[i|1<<j][j][t2]=Math.max(f[i|1<<j][j][t2],t);
}
}
}
}
}
}
int result=0;
for(int i=0;i<(1<<n);++i) {
for(int j=0;j<n;++j) {
for(int k=0;k<3;++k) {
result=Math.max(result,f[i][j][k]);
}
}
}
return result;
}
}

  

topcoder srm 310 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. RSA加解密 私钥加密公钥解密 私加公解 && C++ 调用openssl库 的代码实例

    前提:秘钥长度=1024 ============================================== 对一片(117字节)明文加密  私加 ===================== ...

  2. 在caffe-ssd的环境搭建中遇到报错信息:Makefile:588: recipe for target '.build_release/cuda/src/caffe/layers/softmax_loss_layer.o' failed

    错误原因: 1.计算机没有安装GPU 2.有GPU但是NVCCFLAGS设置错误 解决方法: 1.对没有GPU的计算机,需要将Makefile中的CPU之前的#注释去掉,是的caffe运行的处理器进行 ...

  3. vss使用笔记

    一.四大代码/文档管理软件 (1)     git:具有PR(push request)特性,推送请求.需要负责人审核后才能推送.另外,在推送过程中,git会预编译(合并),分布式代码管理(客户端本地 ...

  4. DX9 DirectX键盘控制程序 代码

    // @time: 2012.3.26 // @author: jadeshu // des: DirectX键盘控制程序 #include <Windows.h> #include &l ...

  5. [1]传奇3服务器源码分析一 LoginGate

    服务端下载地址: 点击这里 网上基本上都有分析该源码的分析详解,如:请点击该链接,但容易晕,而且也不全!所以才有了本文! 一.首先来看服务端的LoginGate源码 先来张图比较让人容易理解

  6. 《大话设计模式》c++实现 模版方法模式

    模板方法模式:定义一个操作中的算法的骨架,而将一些步骤延迟到子类中.模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤. 角色: (1)AbstractClass:是抽象类,其实也 ...

  7. 未能正确加载“EditorPackage”包(转)

    打开vs2012加载项目的时候报如下的错误: 未能正确加载“Microsoft.VisualStudio.Editor.Implementation.EditorPackage”包.此问题可能是由配置 ...

  8. 重建二叉树POJ2255

    重建二叉树 给定一棵二叉树的前序遍历和中序遍历的结果,求其后序遍历. 输入输入可能有多组,以EOF结束.每组输入包含两个字符串,分别为树的前序遍历和中序遍历.每个字符串中只包含大写字母且互不重复.输出 ...

  9. 51ll网产品信息保存为txt文件

    import requests from pyquery import PyQuery as pq url='http://www.51xxx.com/Try/index/p/3' headers={ ...

  10. ID3决策树

    决策树 优点:计算复杂度不高,输出结果易于理解,对中间值的缺少不敏感,可以处理不相关特征数据 缺点:过拟合 决策树的构造 熵:混乱程度,信息的期望值 其中p(xi)是选择分类的概率 熵就是计算所有类别 ...