【2016 ACM/ICPC Asia Regional Qingdao Online】
[ HDU 5878 ] I Count Two Three
考虑极端,1e9就是2的30次方,3的17次方,5的12次方,7的10次方。
而且,不超过1e9的乘积不过5000多个,于是预处理出来,然后每次二分找就可以了。
/*
TASK:I Count Two Three 2^a*3^b*5^c*7^d的最小的大于等于n的数是多少
LANG:C++
URL:http://acm.hdu.edu.cn/showproblem.php?pid=5878
*/
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#define ll long long
using namespace std;
const int N=;
const ll M=1e9+;
int tw,th,fi,se,t,n;
ll two[N]={},three[N]={},five[N]={},seven[N]={};
ll ans[],cnt;
int main() {
for(int i=;two[i-]<M;i++,tw++)
two[i]=two[i-]*;
for(int i=;three[i-]<M;i++,th++)
three[i]=three[i-]*;
for(int i=;five[i-]<M;i++,fi++)
five[i]=five[i-]*;
for(int i=;seven[i-]<M;i++,se++)
seven[i]=seven[i-]*; for(int i=;i<tw;i++)
for(int j=;three[j]*two[i]<M&&j<th;j++)
for(int k=;five[k]*three[j]*two[i]<M&&k<fi;k++)
for(int g=;seven[g]*five[k]*three[j]*two[i]<M&&g<se;g++)
ans[cnt++]=two[i]*three[j]*five[k]*seven[g]; sort(ans,ans+cnt); scanf("%d",&t);
while(t--){
scanf("%d",&n);
printf("%lld\n",ans[lower_bound(ans,ans+cnt,n)-ans]);
}
}
[ HDU 5879 ] Cure
当n很大时,答案趋于1.64493,于是n小时输出预处理的,大时答案就是1.64493。
/*
TASK:求∑1/k^2 k=1到n
LANG:C++
URL:http://acm.hdu.edu.cn/showproblem.php?pid=5879
*/
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#define ll long long
#define N 115000
using namespace std;
char n[];
double ans[N];
void init(){
for(ll i=;i<N;i++)
ans[i]=ans[i-]+1.0/(i*i);
}
double get(){
int a=,len=;
for(int i=;n[i]&&len<;i++,len++)
a=a*+n[i]-'';
if(len==||a>=N)return 1.64493;
return ans[a];
}
int main() {
init();
while(~scanf("%s",n)){
printf("%.5f\n",get());
memset(n,,sizeof n);
}
}
[ HDU 5881 ] Tea
注意最后可以留1升水,所以2升2升地倒向上取整是((r-1)+1)/2 就是r/2,l==0时,先倒了1次1,所以r还要-1;
/*
TASK:壶里有L到R区间的水,倒俩杯里,倒完时相差不超过1,壶里最多可以余1,求最少多少次一定能倒完。
LANG:C++
URL:http://acm.hdu.edu.cn/showproblem.php?pid=5881
*/
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#define ll long long
using namespace std;
ll l,r,ans;
int main() {
while(~scanf("%lld%lld",&l,&r)){
if(r<=)
ans=;
else if(r<=)
ans=;
else if(l==r)
ans=;
else if(l==)//第一次倒l/2+0.5,第二次倒l/2+1.5,然后2、2、2、如果l==0,不如第一次就倒1,然后2、2、2
ans=+(r-)/;
else{
r-=l+;//前两次倒的
ans=+r/;
}
printf("%lld\n",ans);
}
return ;
}
[ HDU 5882 ] Balanced Game
n为奇数就是有n-1个度,只要保证n-1为偶数就存在,所以n为奇数就存在。
[ HDU 5883 ] The Best Path
如果点的度为奇数的有2个或0个,那么存在路,2个则从一个度为奇数的点出发,另一个点结束,起点和终点异或了(du[i]+1)/2次,其它点异或了du[i]/2次。都是偶数的点则以一个点为起点,最后回到它,那么这个点多异或一次。因为du为偶数时,(du[i]+1)/2和du[i]/2相等,所以循环里不用判断了。
/*
TASK:The Best Path 求经过连通图的所有边一次且经过点异或起来值最大的路的异或值
LANG:C++
URL:http://acm.hdu.edu.cn/showproblem.php?pid=5883
*/
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#define ll long long
#define N 100005
using namespace std;
int t,n,m,a[N];
int du[N];
void solve(){
int num=;
for(int i=;i<=n;i++)
if(du[i]%)
num++;
if(num!=&&num){
puts("Impossible");
return;
}
int ans=;
for(int i=;i<=n;i++)
for(int j=;j<=(du[i]+)/;j++)
ans^=a[i];
if(!num){
int tans=ans;
for(int i=;i<=n;i++)
ans=max(ans,tans^a[i]);
}
printf("%d\n",ans);
}
int main() {
scanf("%d",&t);
while(t--){
memset(du,,sizeof du);
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
for(int i=;i<=m;i++){
int u,v;
scanf("%d%d",&u,&v);
du[u]++;
du[v]++;
}
solve();
}
return ;
}
[ HDU 5884 ] Sort
做过类似的,主要要注意的是不能刚好每次k个时,要第一次来合并不足k个的,两个单调队列,一个是合并后的,一个是未合并的,每次合并时选两个队列里小的那个。
二分判断的时候,如果答案已经超过cost,就一定不行了。
/*
TASK:Sort 合并数列,每次合并花费数列大小之和,求总代价不超过T的最小的每次最多合并个数k。
LANG:C++
URL:http://acm.hdu.edu.cn/showproblem.php?pid=5884
*/
#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 100005
#define ll long long
using namespace std;
ll n,t,p;
ll a[N],h[N],cost;//h是合并后的优先队列
ll solve(int k)
{
memset(h,,sizeof h);
t=(n-)/(k-);//需要减少n-1堆,每次减少k-1堆能合并几次。
p=(n-)%(k-);//还要减少p堆(p<k-1)
for(int i=; i<=p; i++)//那就合并前p+1堆
h[]+=a[i];
int top=p+,htop=;
ll ans=p?h[]:;//第一次有合并则加上合并的代价。
for(int i=; i<=t; i++)//k个k个合并t次
{
for(int j=; j<k; j++)//合并k个
if(htop>=i||a[top]<h[htop]&&top<n)//如果合并队列里没有了可选的了,或者未合并队列的更小,则取未合并队列的。
h[i]+=a[top++];
else
h[i]+=h[htop++];
ans+=h[i];//累加答案
if(ans>cost)
return ;
}
if(ans>cost)
return ;
return ;
}
int main()
{
int t;
scanf("%d",&t);
while(t--){
scanf("%lld%lld",&n,&cost);
for(int i=; i<n; i++)
scanf("%lld",&a[i]);
sort(a,a+n);
int l=,r=n;
while (l<r) {
int m=(l+r)/;
if(solve(m))
r=m;
else
l=m+;
}
printf("%d\n",l);
}
return ;
}
[ HDU 5887 ] Herbs Gathering
用map来存状态转移,还要优化一下,去掉体积更大且价值更小的状态。
/*
TASK:Herbs Gathering 容量很大,价值也很大,数量少的01背包问题。
LANG:C++
URL:http://acm.hdu.edu.cn/showproblem.php?pid=5887
*/
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <map>
#define ll long long
using namespace std;
const int N=;
map<ll,ll>mm[N];
map<ll,ll>::iterator it,ij;
int n,t;
ll a[N],b[N];
int main() {
while(~scanf("%d%d",&n,&t)){
for(int i=;i<=n;i++)
mm[i].clear();
mm[][]=;
for(int i=;i<=n;i++){
scanf("%lld%lld",&a[i],&b[i]);
mm[i][]=;
} for(int i=;i<=n;i++){
for(it=mm[i-].begin();it!=mm[i-].end();it++){
if(it->first+a[i]<=t)
{
if(mm[i].count((it->first)+a[i]))
mm[i][(it->first)+a[i]]=max(it->second+b[i],mm[i][(it->first)+a[i]]);
else mm[i][(it->first)+a[i]]=it->second+b[i];
}
if(mm[i].count((it->first)))
mm[i][(it->first)]=max(it->second,mm[i][it->first]);
else
mm[i][it->first]=it->second; ll rm=;
for(ij=mm[i].begin();ij!=mm[i].end();ij++){
//printf("%d [%lld %lld]:[%lld %lld]\n",i,ij->first,ij->second,it->first,it->second);
if(ij->first>it->first &&ij->second<it->second)
rm=ij->first;
else if(ij->first<it->first && ij->second>it->second)
rm=it->first;
}
if(rm)
mm[i].erase(rm);
}
}
ll ans=;
for(it=mm[n].begin();it!=mm[n].end();it++)
ans=max(ans,(it->second)); printf("%lld\n",ans);
} }
[ HDU 5889 ] Barricade
先用bfs求出最短路(经过最少点到达),之后把最短路的边加到网络流的边里,注意这里的权值是给的w,用isap跑网络流比较保险,不容易超时。
/*
TASK:Barricade 求最短路的最小割
LANG:C++
URL:http://acm.hdu.edu.cn/showproblem.php?pid=5889
*/
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
#define ll long long
#define N 1005
#define M 40010
#define inf 0x3f3f3f3f
using namespace std;
struct edge{
int to,next,cap,flow;
}e[M];
int head[N],cnt;
int gap[N],dep[N],cur[N];
void init(){
cnt=;
memset(head, -, sizeof head);
}
void add(int u,int v,int w,int rw=){
e[cnt]=(edge){v,head[u],w,};
head[u]=cnt++;
e[cnt]=(edge){u,head[v],rw,};
head[v]=cnt++;
}
int q[N];
void bfs(int st,int ed){
memset(dep,-,sizeof dep);
memset(gap,,sizeof gap);
gap[]=;
int front=,rear=;
dep[ed]=;
q[rear++]=ed;
while(front!=rear){
int u=q[front++];
for(int i=head[u];~i;i=e[i].next){
int v=e[i].to;
if(dep[v]!=-)continue;
q[rear++]=v;
dep[v]=dep[u]+;
gap[dep[v]]++;
}
}
}
int s[N];
int sap(int st,int ed,int n){
bfs(st,ed);
memcpy(cur,head,sizeof head);
int top=;
int u=st;
int ans=;
while(dep[st]<n){
if(u==ed){
int Min=inf;
int inser;
for(int i=;i<top;i++)
if(Min>e[s[i]].cap-e[s[i]].flow){
Min=e[s[i]].cap-e[s[i]].flow;
inser=i;
}
for(int i=;i<top;i++){
e[s[i]].flow+=Min;
e[s[i]^].flow-=Min;
}
ans+=Min;
top=inser;
u=e[s[top]^].to;
continue;
}
bool flag=false;
int v;
for(int i=cur[u];~i;i=e[i].next){
v=e[i].to;
if(e[i].cap-e[i].flow&&dep[v]+==dep[u]){
flag=true;
cur[u]=i;
break;
}
}
if(flag){
s[top++]=cur[u];
u=v;
continue;
}
int Min=n;
for(int i=head[u];~i;i=e[i].next)
if(e[i].cap-e[i].flow &&dep[e[i].to]<Min){
Min=dep[e[i].to];
cur[u]=i;
}
gap[dep[u]]--;
if(!gap[dep[u]])return ans;
gap[dep[u]=Min+]++;
if(u!=st)u=e[s[--top]^].to;
}
return ans;
}
int n,m;
int g[N][N],vis[N],d[N];
void solve(){
int l=,r=;
q[]=;
d[]=;
memset(vis,,sizeof vis);
while(l<=r){
int k=q[l++];
for(int i=;i<=n;i++)if(g[k][i]!=-){
if(vis[i])continue;
q[++r]=i;
vis[i]=;
d[i]=d[k]+;
}
}
init();
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
if(g[i][j]!=-&&d[j]==d[i]+)
add(i,j,g[i][j]); printf("%d\n",sap(,n,n));
}
int main() {
int t;
scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
memset(g,-,sizeof g);
for(int i=;i<=m;i++){
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
g[v][u]=g[u][v]=w;
}
solve();
}
return ;
}
小结:这次比赛既没带草稿纸又没带笔,还迟到,我们的态度太不认真了,不过睡得那么晚我真是起不来啊。我觉得我们还要多练多做,我发现很多基本的知识都不熟悉。
【2016 ACM/ICPC Asia Regional Qingdao Online】的更多相关文章
- HDU 5889 Barricade 【BFS+最小割 网络流】(2016 ACM/ICPC Asia Regional Qingdao Online)
Barricade Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total S ...
- 2016 ACM/ICPC Asia Regional Qingdao Online 1001/HDU5878 打表二分
I Count Two Three Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- 2016 ACM/ICPC Asia Regional Qingdao Online(2016ACM青岛网络赛部分题解)
2016 ACM/ICPC Asia Regional Qingdao Online(部分题解) 5878---I Count Two Three http://acm.hdu.edu.cn/show ...
- hdu 5878 I Count Two Three (2016 ACM/ICPC Asia Regional Qingdao Online 1001)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5878 题目大意: 给出一个数n ,求一个数X, X>=n. X 满足一个条件 X= 2^a*3^ ...
- Hdu OJ 5884-Sort (2016 ACM/ICPC Asia Regional Qingdao Online)(二分+优化哈夫曼)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5884 题目大意:有n个有序的序列,对于第i个序列有ai个元素. 现在有一个程序每次能够归并k个序列, ...
- 2016 ACM/ICPC Asia Regional Qingdao Online HDU5889
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5889 解法:http://blog.csdn.net/u013532224/article/details ...
- 2016 ACM/ICPC Asia Regional Qingdao Online HDU5883
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5883 解法:先判断是不是欧拉路,然后枚举 #pragma comment(linker, "/S ...
- 2016 ACM/ICPC Asia Regional Qingdao Online HDU5882
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5882 解法:一个点必须出度和入度相同就满足题意,所以加上本身就是判断奇偶性 #include<std ...
- 2016 ACM/ICPC Asia Regional Qingdao Online HDU5879
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5879 解法:我们知道到某个极限之后结果相同,所以找到那个极限,其他保存之后输出就好了 #include&l ...
随机推荐
- 时间就像Hourglass一样,积累(沉淀)越多,收获越大
package cn.bdqn; public class Hourglass { public static void main(String[] args) { for (int i = 2; i ...
- java 22 - 4 多线程的代码实现的方式1
需求:我们要实现多线程的程序. 如何实现呢? 由于线程是依赖进程而存在的,所以我们应该先创建一个进程出来. 而进程是由系统创建的,所以我们应该去调用系统功能创建一个进程. Java是不能直接调用系统功 ...
- SOAP-XML请求(iOS应用下集成携程api)
用携程机票为例: 携程联盟 飞机票.门票 联盟ID:278639 站点ID:739462 密钥KEY:BE57B925-E8CE-4AA2-AC8E-3EE4BBBB686F API_URL:open ...
- C#实现php的hash_hmac函数
from:http://blog.csdn.net/ciaos/article/details/12618487 PHP代码示例如下 <?php $res1 = hash_hma ...
- smarty foreach循环
1,smarty foreach1,单纯的数组array(1000,2000,3000),使用foreach(from = $array item=foo){$foo}2,键值对数组<ul> ...
- DEDECMS之十 修改织梦链和文章的默认来源及作者
今天在用织梦搭网站的时候,发现了两个问题,一个就是最新的dedecms5.7系统中默认会加上“织梦链”这一个链接组,织梦的做法是可以理解的, 但是给别人做网站,这些链接是不能要的,所以在数据库,模板文 ...
- 带参数的CLR存储过程
昨天有学习<简单创建与布署CLR存储过程>http://www.cnblogs.com/insus/p/4371762.html,知道怎样创建以及布署至SQL中去. 下面这个范例是实现CL ...
- codevs 3165 爱改名的小融2
3149 爱改名的小融 2 http://codevs.cn/problem/3149/ 题目描述 Description Wikioi上有个人叫小融,他喜欢改名.现在他的要求变了,只要是英文字母就是 ...
- 64位centos 下编译 hadoop 2.6.0 源码
64位os下为啥要编译hadoop就不解释了,百度一下就能知道原因,下面是步骤: 前提:编译源码所在的机器,必须能上网,否则建议不要尝试了 一. 下载必要的组件 a) 下载hadoop源码 (当前最新 ...
- Python2.2-原理之类型和运算
此节来自于<Python学习手册第四版>第二部分 一.Python对象类型(第4章) 1. Python可以分解成模块.语句.表达式以及对象:1.程序由模块构成:2.模块包含语句:3.语句 ...