CCPC 2017-2018, Finals Solution
A - Dogs and Cages
水。
#include <bits/stdc++.h>
using namespace std; int t;
double n; int main()
{
scanf("%d", &t);
for (int kase = ; kase <= t; ++kase)
{
scanf("%lf", &n);
printf("Case #%d: %.10f\n", kase, n - );
}
return ;
}
B - Same Digit
留坑。
C - Rich Game
题意:有两个人,A可以控制输赢,但是没有钱,B有无限的钱,他们打羽毛球,至少要获得11个点并且要比对方至少多获得两个点才能赢下当局,如果A 赢了 一个点,A要给B Y元,否则 B 给A X 元 求他们一共打K局的情况下,A最多可以赢多少局
思路:显然,当x > y 的时候 可以赢k局
考虑 x <= y 的情况 根据贪心的思路,假设A 要输 t 局
那么 必然要满足 $11yt >= (k - t)(11y - 9x)$
#include <bits/stdc++.h>
using namespace std; int t, x, y, k; int main()
{
scanf("%d", &t);
for (int kase = ; kase <= t; ++kase)
{
printf("Case #%d: ", kase);
scanf("%d%d%d", &x, &y, &k);
if (x > y) printf("%d\n", k);
else
{
int t = (int)ceil(k * ( * y - * x) * 1.0 / ( * y + * x));
printf("%d\n", k - t);
}
}
return ;
}
D - Mr. Panda and Circles
留坑。
E - Evil Forest
水。
#include <bits/stdc++.h>
using namespace std; #define N 1010 int t, n, sum, num; int main()
{
scanf("%d", &t);
for (int kase = ; kase <= t; ++kase)
{
scanf("%d", &n); sum = ;
for (int i = ; i <= n; ++i)
{
scanf("%d", &num);
sum += num;
sum += (num % ) ? (num / ) + : (num / );
}
printf("Case #%d: %d\n", kase, sum);
}
return ;
}
F - Fair Lottery
留坑。
G - Alice’s Stamps
题意:给出M个区间,选择K个区间,使得选择的元素尽量多,区间可以交叉
思路:$dp[i][j]$ 表示 第i位,选择k个区间的时候,数量最多是多少
三个状态转移
$dp[i + 1][j] = max(dp[i][j], dp[i + 1][j])$
$dp[i][j +1] = max(dp[i][j], dp[i][j + 1])$
$dp[i + cnt][j + 1] = max(dp[i + cnt][j], dp[i][j] + cnt)$
cnt 为 那个区间最长能到哪里
 #include<bits/stdc++.h>
 using namespace std;
 #define N 2010
 int dp[N][N];
 struct node{
     int l, r;
     inline node(){}
     inline node(int l, int r) :l(l), r(r){}
     inline bool operator < (const node &b) const
     {
         return l == b.l ? r > b.r : l < b.l;
     }
 }arr[N];
 int n, m, k;
 int cnt, val;
 int main()
 {
     int t;
     scanf("%d",&t);
     for(int cas = ; cas <= t; ++cas)
     {
         scanf("%d %d %d" , &n, &m, &k);
         for(int i = ; i <= m; ++i)
         {
             scanf("%d %d", &arr[i].l, &arr[i].r);
         }
         sort(arr + , arr +  + m);
         memset(dp, , sizeof dp);
         val = ;
         cnt = ;
         for(int i = ; i < n; ++i)
         {
             while(cnt <= m && arr[cnt].l == i + )
             {
                 val = max(val, arr[cnt].r - arr[cnt].l + );
                 cnt++;
             }
             for(int j = ; j <= k; ++j)
             {
                 dp[i + ][j] = max(dp[i + ][j], dp[i][j]);
                 dp[i][j + ] = max(dp[i][j], dp[i][j + ]);
                 dp[i + val][j + ] = max(dp[i + val][j + ], dp[i][j] + val);
             }
             if(val) --val;
         }
         printf("Case #%d: %d\n", cas, dp[n][k]);
     }
     return ;
 }
H - Equidistance
留坑。
I - Inkopolis
留坑。
J - Subway Chasing
留坑。
K - Knightmare
题意:在无限大的棋盘上,马走日,有多少个点是能够走到的
思路:BFS找规律,二阶差分
#include <bits/stdc++.h>
using namespace std; #define ull unsigned long long int arr[] = {, , , , , , }; int t;
ull n; int main()
{
scanf("%d", &t);
for (int kase = ; kase <= t; ++kase)
{
printf("Case #%d: ", kase);
scanf("%llu", &n);
if (n <= ) printf("%d\n", arr[n]);
else
{
ull sum = ; n -= ;
sum += (ull) * n + (ull) * n * (n + );
printf("%llu\n", sum);
}
}
return ;
}
CCPC 2017-2018, Finals Solution的更多相关文章
- MyEclips 2017/2018 (mac 版)安装与破解
		MyEclips 2017/2018 (mac 版)安装与破解 现在在学J2EE,然后使用的工具就是 MyEclipse,现在就抛弃 Eclipse 了,我就不多说它俩的区别了,但是 MyEclips ... 
- MyEclipse 2017/2018 安装与破解 图文教程
		SSM 框架-02-MyEclipse 2017/2018 安装与破解 现在在学J2EE,然后使用的工具就是 MyEclipse,现在就抛弃 Eclipse 了,我就不多说它俩的区别了,但是 MyEc ... 
- </2017><2018>
		>>> Blog 随笔原始文档及源代码 -> github: https://github.com/StackLike/Python_Note >>> 统计信 ... 
- CCPC 2016-2017, Finals Solution
		A - The Third Cup is Free 水. #include<bits/stdc++.h> using namespace std; ; int n; int arr[max ... 
- 我的2017&2018
		最近项目进入验收阶段,所以上班没那么忙碌了,但是怎么说呢,我可能天生是闲不住的主,觉得浑身不自在(我这样的人是不是特别不会享福),此处应该有个笑脸哈. 翻看了博客园好几个大牛写的技术文章,感慨大牛不愧 ... 
- [2017 - 2018 ACL] 对话系统论文研究点整理
		(论文编号及摘要见 [2017 ACL] 对话系统. [2018 ACL Long] 对话系统. 论文标题[]中最后的数字表示截止2019.1.21 google被引次数) 1. Domain Ada ... 
- CorelDRAW X7 X8 2017 2018是什么关系?
		从CorelDRAW 2017版本开始我们叫习惯了的X几系列的CorelDRAW毅然决然的就换了称呼,所以有时候很多朋友对于软件版本,经常会傻傻分不清,还有人认为X8版本比2017版本高,究竟为什么会 ... 
- JetBrains 2017/2018全系列产品激活工具
		可谓是工欲善其事,必先利其器,相信作为优秀开发工程师的你都想拥有一套快捷高效的编码工具,而JetBrains这家公司的产品,不管是那种编程语言,其开发工具确实让开发者们着迷,JetBrains的产品博 ... 
- 2018-2019 ACM-ICPC, Asia East Continent Finals Solution
		D. Deja vu of … Go Players 签. #include <bits/stdc++.h> using namespace std; int t, n, m; int m ... 
随机推荐
- 什么是LTE?
			LTE是英文Long Term Evolution的缩写.LTE也被通俗的称为3.9G,具有100Mbps的数据下载能力,被视作从3G向4G演进的主流技术.它改进并增强了3G的空中接入技术,采用OFD ... 
- Oracle应用技术精华教程:管理还原段
			管理还原段 在oracle 9i 之后提供了两种方法来管理还原数据 自动的还原数据管理:oracle 自动管理还原段的创建.分配和优化 手动的还原数据管理:oracle 手动管理还原段的创建.分配和优 ... 
- 将Eclipse项目导入到Android studio 中 很多点9图出现问题解决方法
			在build.gradle里添加以下两句: aaptOptions.cruncherEnabled = false aaptOptions.useNewCruncher = false 
- ubuntu的安装方法
			Ubuntu 是一个启动速度超快.界面友好.安全性好的开源操作系统,它由全球顶尖开源软件专家开发,适用于桌面电脑.笔记本电脑.服务器以及上网本等,并且它可以永久免费使用.如果你厌倦了Windows,如 ... 
- Android英文文档翻译系列(4)——PopupWindow
			public class PopupWindow extends Object //直接继承至Object java.lang.Object ↳ android.widget.PopupWindow ... 
- java基础---->Java关于复制的使用(一)
			这里简单记录一下java中关于浅复制和深复制的知识.很多时候,一个人选择了行走,不是因为欲望,也并非诱惑,他仅仅是听到了自己内心的声音. java中的复制clone方法 一.java对象的浅复制 一个 ... 
- Python学习之k-近邻算法
			1. K-近邻算法 # coding=utf-8 from numpy import * import operator def createDataSet(): group = array([[1. ... 
- Java可视化JVM监控软件
			jdk自带.jdk安装目录下 1.JConsole 选择 不安全 可用不多 2.VisualVM 
- linux常用的一些访问目录
			救命三键(Ctrl+Alt+Delete) /var/log 如果是网络服务的问题时,请到 这个目录里头去查阅一下 log file (登录档): /etc/rc.local 修改挂载 ... 
- NodeJS收发GET和POST请求
			目录: 一 express框架接收 二 接收Get 三 发送Get 四 接收Post 五 发送Post 一 express框架接收 app.get('/',function(req,res) { va ... 
