2016 China Collegiate Programming Contest Final
2016 China Collegiate Programming Contest Final
Table of Contents 2016 China Collegiate Programming Contest FinalProblem A:Problem J:Problem H:
Problem A:
题意:喝咖啡,每三杯就又可以有免费一杯,求最少花费;
分析:贪心;
#include <bits/stdc++.h>
using namespace std;
const int inf = 0x3f3f3f3f;
const int maxn = 100000+5;
int a[maxn];
int main()
{
int t;
scanf("%d",&t);
int kase = 0;
while(t--) {
int n;
scanf("%d",&n);
int sum = 0;
for(int i=0;i<n;i++) {
scanf("%d",&a[i]);
sum +=a[i];
}
sort(a,a+n);
for(int i=n-3;i>=0;i-=3)
sum-=a[i];
printf("Case #%d: %d\n",++kase,sum);
}
return 0;
}
Problem J:
题意:题意很长,CCPC比赛规则,给出一个队伍,看他是否能进WF,CCPC分两个部分,X 是从五大赛区中选X个,Y是在EC比赛中选Y个,X+Y = G,G是确定的,然后调整X,Y使得给出的这个队伍恰好不能进WF时的最小Y,要是无论怎么调整XY,都能进WF,输出ADVANCED!
分析:g<=20 记录两种规则中的这个队伍的排名k,kk,枚举x,y即可;
#include <bits/stdc++.h>
using namespace std;
string a1[25],a2[25],a3[25],a4[25],a5[25];
string ec[25];
int main()
{
//freopen("in.txt","r",stdin);
int kase = 1;
int t;
scanf("%d",&t);
while(t--)
{
int g;
scanf("%d",&g);
string ans;
cin>>ans;
for(int i=0; i<20; i++)
cin>>a1[i];
for(int i=0; i<20; i++)
cin>>a2[i];
for(int i=0; i<20; i++)
cin>>a3[i];
for(int i=0; i<20; i++)
cin>>a4[i];
for(int i=0;i<20;i++)
cin>>a5[i];
for(int i=0; i<20; i++)
cin>>ec[i];
int k = 1;
set<string> s;
bool flag = false;
for(int i=0; i<20; i++)
{
for(int j=0; j<5; j++)
{
if(j==0)
{
if(ans==a1[i])
{
flag = true;
break;
}
else if(!s.count(a1[i]))
{
s.insert(a1[i]);
k++;
continue;
}
}
if(j==1)
{
if(ans==a2[i])
{
flag = true;
break;
}
else if(!s.count(a2[i]))
{
s.insert(a2[i]);
k++;
continue;
}
}
if(j==2)
{
if(ans==a3[i])
{
flag = true;
break;
}
else if(!s.count(a3[i]))
{
s.insert(a3[i]);
k++;
continue;
}
}
if(j==3)
{
if(ans==a4[i])
{
flag = true;
break;
}
else if(!s.count(a4[i]))
{
s.insert(a4[i]);
k++;
continue;
}
}
if(j==4)
{
if(ans==a5[i])
{
flag = true;
break;
}
else if(!s.count(a5[i]))
{
s.insert(a5[i]);
k++;
continue;
}
}
}
if(flag)
break;
}
int kk = 1;
for(int i=0;i<20;i++) {
if(ans==ec[i])
break;
else if(!s.count(ec[i])) {
kk++;
s.insert(ec[i]);
}
}
int yy = -1;
for(int i=0;i<=g;i++) {
int x = g-i;
int y = i;
if(x<k&&y<kk)
{
yy = y;
break;
}
}
if(yy==-1)
printf("Case #%d: ADVANCED!\n",kase++);
else printf("Case #%d: %d\n",kase++,yy);
}
return 0;
}
Problem H:
题意:n个工程项目,m 个工程师,工程师会一些项目,每一个工程项目需要一些工程项目,每个工程师只能去一个工程,求最多能完成多少个工程项目;
分析:n,m<=10 可以考虑集合上DP,考虑每一个工程师选或不选,但是不能直接用人数状态去循环遍历可以完成哪些项目;要优化,预处理,第i个项目,有哪些人数状态可以完成,然后dp的时候,只要考虑这两个集合是否有包含关系,改成了一重循环;
tip: 值得注意的是,最后的结果不是max(dp(i,(1<<m)-1)) ,而是人数的s状态要考虑。
#include <bits/stdc++.h>
using namespace std;
int c[20][10],d[20][10];
int p[120];
int dp[20][1<<11];
int main()
{
int t;
int n,m;
scanf("%d",&t);
int kase = 1;
while(t--)
{
scanf("%d%d",&n,&m);
vector<int> a[20];
memset(dp,0,sizeof(dp));
for(int i=1; i<=n; i++)
{
scanf("%d",&c[i][0]);
for(int j=1; j<=c[i][0]; j++)
scanf("%d",&c[i][j]);
}
for(int i=0; i<m; i++)
{
scanf("%d",&d[i][0]);
for(int j=1; j<=d[i][0]; j++)
scanf("%d",&d[i][j]);
}
for(int i=1; i<=n; i++)
{
for(int s=0; s<(1<<m); s++)
{
int cnt=0;
memset(p,0,sizeof(p));
for(int k=0; k<m; k++)
{
if(s&(1<<k))
{
cnt++;
for(int j=1; j<=d[k][0]; j++)
p[d[k][j]]=1;
}
}
int flag=1;
for(int j=1; j<=c[i][0]; j++)
if(p[c[i][j]]==0) flag=0;
if(flag) a[i].push_back(s); //第i个项目,有哪些人完成
}
}
for(int i=1; i<=n; i++)
{
for(int s=0; s<(1<<m); s++)
{
for(int j=0; j<a[i].size(); j++)
{
if((s|a[i][j])==s)
{
dp[i][s]=max(dp[i-1][s-a[i][j]]+1,dp[i][s]);
}
}
dp[i][s]=max(dp[i][s],dp[i-1][s]);
}
}
printf("Case #%d: %d\n",kase++,dp[n][(1<<m)-1]);
}
return 0;
}
2016 China Collegiate Programming Contest Final的更多相关文章
- 2018 China Collegiate Programming Contest Final (CCPC-Final 2018)-K - Mr. Panda and Kakin-中国剩余定理+同余定理
2018 China Collegiate Programming Contest Final (CCPC-Final 2018)-K - Mr. Panda and Kakin-中国剩余定理+同余定 ...
- 2018 China Collegiate Programming Contest Final (CCPC-Final 2018)
Problem A. Mischievous Problem Setter 签到. #include <bits/stdc++.h> using namespace std; #defin ...
- 2017 China Collegiate Programming Contest Final (CCPC 2017)
题解右转队伍wiki https://acm.ecnu.edu.cn/wiki/index.php?title=2017_China_Collegiate_Programming_Contest_Fi ...
- 模拟赛小结:2017 China Collegiate Programming Contest Final (CCPC-Final 2017)
比赛链接:传送门 前期大顺风,2:30金区中游.后期开题乏力,掉到银尾.4:59绝杀I,但罚时太高卡在银首. Problem A - Dogs and Cages 00:09:45 (+) Solve ...
- 模拟赛小结:2018 China Collegiate Programming Contest Final (CCPC-Final 2018)
比赛链接:传送门 跌跌撞撞6题摸银. 封榜后两题,把手上的题做完了还算舒服.就是罚时有点高. 开出了一道奇奇怪怪的题(K),然后ccpcf银应该比区域赛银要难吧,反正很开心qwq. Problem A ...
- 2018 China Collegiate Programming Contest Final (CCPC-Final 2018)(A B G I L)
A:签到题,正常模拟即可. #include<bits/stdc++.h> using namespace std; ; struct node{ int id, time; }; nod ...
- The 2015 China Collegiate Programming Contest A. Secrete Master Plan hdu5540
Secrete Master Plan Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Othe ...
- The 2015 China Collegiate Programming Contest Game Rooms
Game Rooms Time Limit: 4000/4000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- The 2019 China Collegiate Programming Contest Harbin Site F. Fixing Banners
链接: https://codeforces.com/gym/102394/problem/F 题意: Harbin, whose name was originally a Manchu word ...
随机推荐
- 《UML和模式应用(原书第3版)》目录
学习 <UML和模式应用(原书第3版)>目标: 理解OOA/D思想 如何使用UML建模 如何使用设计模式 如何设计分层架构 目录: 第1部分 绪论 第1章 面向对象分析和设计 第2章 迭代 ...
- JAVA实体类不要使用基本类型,基本类型包含byte、int、short、long、float、double、char、boolean
由于JAVA的基本类型会有默认值,例如当某个类中存在private int age;字段时,创建这个类时,age会有默认值0.当使用age属性时,它总会有值.因此在某些情况下,便无法实现age为nu ...
- oracle 单实例DG(配置篇二)
一,DG搭建实例--主库配置 one : 归档配置 01,查看归档 1 select log_mode,force_logging from v$database; 02,开启归档 关闭数据库重新启 ...
- (转)用shell脚本实现杨辉三角的4个实例!
概述: 中国古代数学家在数学的许多重要领域中处于遥遥领先的地位.中国古代数学史曾经有自己光辉灿烂的篇章,而杨辉三角的发现就是十分精彩的一页.杨辉三角形,是二项式系数在三角形中的一种几何排列.杨辉 ...
- VUE中toast的使用与开发
在这篇文章中介绍了toast是什么,这篇文章主要介绍toast的开发与使用. 开发 Vuejs很流行,并且官方也给出了路由插件vue-router.数据管理插件vuex,但是我们仅仅停留在了使用的阶段 ...
- springsource-tool-suite下载(sts)
1 新版本的插件下载 1 直接进入官网下载即可 官网地址:http://spring.io/tools/sts/all. 2 spring官网上下载历史版本的spring插件 1 获取新版本的插件的地 ...
- vim配置clojure开发环境备忘录
1 需要使用的插件 vundle 使用教程 http://www.cnblogs.com/respawn/archive/2012/08/21/2649483.html vim-fireplace h ...
- pat02-线性结构4. Pop Sequence (25)
02-线性结构4. Pop Sequence (25) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue Given ...
- Windows x64位通过PEB获得Kernel32基地址
在64位系统下 gs:[0x30] 指向TEB gs:[0x60] 指向PEB kd> dt _TEB nt!_TEB +0x000 NtTib : _NT_TIB +0x000 Excepti ...
- linux下为.net core应用创建守护进程
1.Supervisor 安装 yum install python-setuptools easy_install supervisor 2.配置 Supervisor mkdir /etc/sup ...