【Round #36 (Div. 2 only) C】Socks Pairs
【题目链接】:https://csacademy.com/contest/round-36/task/socks-pairs/
【题意】
给你n种颜色的袜子,每种颜色颜色的袜子有ai只;
假设你在取袜子的时候不看取出来的是什么颜色,也不看抽屉里面;
问你最少要取多少只,才能保证,里面至少有k双袜子;
【题解】
先特判无解的情况;
若∑a[i]2<k,则无解;
如果有解;
则,先每种颜色的袜子都取一只;
这是最坏的情况了;
接下来,每种颜色的袜子都连续两双的取;
比如现在你有3只袜子了,一共也只有3种颜色的袜子供选;
你所拥有的3只,每只的颜色都不同;
然后再让你取;
你肯定是某种颜色的袜子再连续取2只;
这样,2只才贡献一个新的颜色;
而不是选两个不同的颜色,那样两只就贡献两个颜色了,不是最坏情况;
这样,我们先把所有的a[i]都减去1;
然后每种袜子都两只两只地取;
(奇数的话,1留着);
如果这样取够k双袜子了,则输出(k-1)*2+n+1
这里(k-1)*2表示取(k-1)次两双两双的情况,n是一开始取的n只不同颜色的袜子;
这时再取一只,就能保证有k只袜子了;
如果这样取不够k只袜子;
因为我们已经判断过有解,则减过1之后为奇数的a[i],选完之后,就只剩一只袜子可以选了,这里的1只的个数肯定够凑满k双袜子了,只不过选一只就要增加一对了..
这也是为什么它要放在连续两只后再考虑的原因;
这种情况下答案为已选的袜子对数*2+n+k-已选的袜子对数
【Number Of WA】
3
【反思】
比赛的时候完全没想到,每种袜子都是独立的,可以分开来连续两只地选.
以为要全都一样的数量一起两只两只选.
思维僵化…
最后稀里糊涂地就水过了。。
【完整代码】
#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
#define Open() freopen("F:\\rush.txt","r",stdin)
#define Close() ios::sync_with_stdio(0)
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 1e5;
int n,k;
LL a[N+100],d[N+100],tans = 0;
void sp(){
LL cnt = 0;
rep1(i,1,n) cnt = cnt + a[i]/2;
if (cnt < k){
cout << -1 << endl;
exit(0);
}
}
int main(){
//Open();
Close();
cin >> n >> k;
rep1(i,1,n)
cin >> a[i];
sp();
rep1(i,1,n) a[i]--;
LL now = 0;
rep1(i,1,n){
now += a[i]/2;
tans += a[i]/2*2;
}
if (now >= k){
cout << (k-1)*2 + n + 1 << endl;
}else{
cout << tans + k - now << endl;
}
return 0;
}
【Round #36 (Div. 2 only) C】Socks Pairs的更多相关文章
- 【Round #36 (Div. 2 only) B】Safe Spots
[题目链接]:https://csacademy.com/contest/round-36/task/safe-spots/ [题意] 给你n个数字构成的序列; 每个位置上的数都由0和1组成; 对于每 ...
- 【CS Round #36 (Div. 2 only) A】Bicycle Rental
[题目链接]:https://csacademy.com/contest/round-36/task/bicycle-rental/ [题意] 让你从n辆车中选一辆车; 每一辆车有3个属性 1.到达车 ...
- Codeforces Round #262 (Div. 2) A. Vasya and Socks【暴力/模拟/袜子在可以在合法情况下增加后用几天】
A. Vasya and Socks time limit per test 1 second memory limit per test 256 megabytes input standard i ...
- 【CS Round #37 (Div. 2 only) D】Reconstruct Graph
[Link]:https://csacademy.com/contest/round-37/task/reconstruct-graph/statement/ [Description] 给你一张图; ...
- 【CS Round #37 (Div. 2 only) B】Group Split
[Link]:https://csacademy.com/contest/round-37/task/group-split/ [Description] 让你把一个数分成两个数a.b的和; (a,b ...
- 【CS Round #37 (Div. 2 only) A】Boring Number
[Link]:https://csacademy.com/contest/round-37/task/boring-number/ [Description] 让你找离平均数最近的一个数的下标; [S ...
- 【CS Round #39 (Div. 2 only) D】Seven-segment Display
[Link]:https://csacademy.com/contest/round-39/task/seven-segment-display/ [Description] 0..9各自有一个数字, ...
- 【CS Round #39 (Div. 2 only) C】Reconstruct Sum
[Link]:https://csacademy.com/contest/round-39/task/reconstruct-sum/ [Description] 给你一个数字S; 让你找有多少对A, ...
- 【CS Round #39 (Div. 2 only) B】Circle Elimination
[Link]:https://csacademy.com/contest/round-39/task/circle-elimination/ [Description] [Solution] 把n个点 ...
随机推荐
- 叁、js中的css
一.子选择器:用来选择一个父元素直接的子元素,不包括子元素的子元素,它的符号为“>” 注:ie6不支持子代选择器. <!DOCTYPE html PUBLIC "-//W3C// ...
- 洛谷P2770 航空路线问题 最小费用流
Code: #include<cstdio> #include<iostream> #include<algorithm> #include<vector&g ...
- JS函数传参传入对象
例如: value为一个对象 value={} var valueStr = JSON.stringify(value); 对象转字符串 "<a style='cursor: poin ...
- 【mysql】 mysql 子查询、联合查询、模糊查询、排序、聚合函数、分组----------语法
第二章 mysql 一.模糊查询 like 1. 字段 like '河北省%' %代表任何N个字符 2 字段 like '河北省____' _代表任意1个字符 二.IN 语法:SELECT 字段列1, ...
- Oralce中的package和package body
1.Oracle Package的作用: 可以简化应用设计.提高应用性能.实现信息隐藏.子程序重载 2.ORACLE中的function .package.package bodies.pro ...
- svn文件管理器的使用
服务器端: 客户端 使用SVN的注意事项 做任何操作之前,先update一下 不要修改其他人的文件 不要在SVN里直接打开.编辑文件 不要在打开.编辑文件的时候,进行操作 SVN客户端的安装,非常简单 ...
- nested exception is java.lang.NoClassDefFoundError: org/codehaus/jettison/json/JSONObject异常的解决办法
解决办法:你可以尝试添加一个jar包,因为我加入了一个jar包后错误问题成功解决. 将所需要的jettison-1.2.jar包复制到lib文件夹里面,重启项目,问题搞定.
- java实现上传图片
1.将图片上传到tomcat下 2.将相对路径存放到数据库中 @RequestMapping(params="upLoadPicture") @ResponseBody publi ...
- hihocoder 1124 : 好矩阵 dp
好矩阵 时间限制:3000ms 单点时限:1000ms 内存限制:256MB 描写叙述 给定n, m.一个n × m矩阵是好矩阵当且仅当它的每一个位置都是非负整数,且每行每列的和 ≤ 2.求好矩阵的个 ...
- 【C语言】递归函数DigitSum(n)
//写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和, //比如,调用DigitSum(1729),则应该返回1+7+2+9,它的和是19 #include <std ...