【题目链接】: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的更多相关文章

  1. 【Round #36 (Div. 2 only) B】Safe Spots

    [题目链接]:https://csacademy.com/contest/round-36/task/safe-spots/ [题意] 给你n个数字构成的序列; 每个位置上的数都由0和1组成; 对于每 ...

  2. 【CS Round #36 (Div. 2 only) A】Bicycle Rental

    [题目链接]:https://csacademy.com/contest/round-36/task/bicycle-rental/ [题意] 让你从n辆车中选一辆车; 每一辆车有3个属性 1.到达车 ...

  3. 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 ...

  4. 【CS Round #37 (Div. 2 only) D】Reconstruct Graph

    [Link]:https://csacademy.com/contest/round-37/task/reconstruct-graph/statement/ [Description] 给你一张图; ...

  5. 【CS Round #37 (Div. 2 only) B】Group Split

    [Link]:https://csacademy.com/contest/round-37/task/group-split/ [Description] 让你把一个数分成两个数a.b的和; (a,b ...

  6. 【CS Round #37 (Div. 2 only) A】Boring Number

    [Link]:https://csacademy.com/contest/round-37/task/boring-number/ [Description] 让你找离平均数最近的一个数的下标; [S ...

  7. 【CS Round #39 (Div. 2 only) D】Seven-segment Display

    [Link]:https://csacademy.com/contest/round-39/task/seven-segment-display/ [Description] 0..9各自有一个数字, ...

  8. 【CS Round #39 (Div. 2 only) C】Reconstruct Sum

    [Link]:https://csacademy.com/contest/round-39/task/reconstruct-sum/ [Description] 给你一个数字S; 让你找有多少对A, ...

  9. 【CS Round #39 (Div. 2 only) B】Circle Elimination

    [Link]:https://csacademy.com/contest/round-39/task/circle-elimination/ [Description] [Solution] 把n个点 ...

随机推荐

  1. Xshell调整终端显示的最大行数(缓冲区)

    1 选择会话,按顺序点击文件->属性 ,打开"会话属性"窗口 如下 在"会话属性"窗口中选择“终端” 修改缓冲区大小的值:其范围为0~2147483647 ...

  2. 使用python绘制词云

    最近在忙考试的事情,没什么时间敲代码,一个月也没几天看代码,最近看到可视化的词云,看到网上也很多这样的工具, 但是都不怎么完美,有些不支持中文,有的中文词频统计得莫名其妙.有的不支持自定义形状.所有的 ...

  3. frameset宽屏居中写法

    在写frameset的时候发现页面较小的时候不能在屏幕上居中,记录一下frameset页面居中的写法 <frameset cols="*,1280,*" frameborde ...

  4. SpringBoot学习笔记(14)----应用监控-HTTP方式

    SpringBoot提供了三种应用监控的方式 通过HTTP(最简单方便) 通过JMX 通过远程shell 这里就是用最简单的方式来使用SpringBoot的应用监控 首先引入依赖,pom文件如下 &l ...

  5. SpringBoot学习笔记(11)-----SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用

    1. activemq 首先引入依赖 pom.xml文件 <dependency> <groupId>org.springframework.boot</groupId& ...

  6. [TJOI2015]弦论(后缀数组or后缀自动机)

    解法一:后缀数组 听说后缀数组解第k小本质不同的子串是一个经典问题. 把后缀排好序后第i个串的本质不同的串的贡献就是\(n-sa[i]+1-LCP(i,i-1)\)然后我们累加这个贡献,看到哪一个串的 ...

  7. BZOJ 2154/2693 Crash的数字表格/jzptab (莫比乌斯反演)

    题目大意:求$\sum_{i=1}^{n}\sum_{j=1}^{m}lcm(i,j)$的和 易得$\sum_{i=1}^{n}\sum_{j=1}^{m}\frac{ij}{gcd(i,j)}$ 套 ...

  8. mysql 修改默认的引擎

      需求: mysql 的默认的引擎为MyISAM  虽然该引擎访问的速度快,但并不支持存储事物,也不支持外键,所以我们修改为innob Linux修改MySql默认存储引擎为InnoDB     一 ...

  9. mysql索引的使用及优化方法

    数据库高级管理及优化 MySQL性能优化 优化MySQL数据库是数据库管理员和数据库开发人员的必备技能.优化MySQL,一方面是找出系统的瓶颈,提高MySQL数据库整体的性能:另一方面是合理设计结构和 ...

  10. hbase报错Could not initialize class org.apache.hadoop.hbase.protobuf.ProtobufUtil

    Caused by: java.lang.RuntimeException: java.io.IOException: java.lang.reflect.InvocationTargetExcept ...