Codeforces Round #762 (Div. 3), CDE
(C) Wrong Addition
题意
定义一种计算方式, 对于a+b=c, 给出a和c, 求b
题解
因为求法是从个位求得, 先求出来的最后输出, 符合栈的存储方式, 所以b用栈来存
每次拿c的最后一位(若小于a最后一位, 则取后两位)减去a的最后一位, 存入b的栈
需要注意的是,: 1.若c已经没了, 但是a还有, 则无解
2. 若c中出现00则无解(下面代码中, 以c后两位<a最后一位判断的)
3. 减去后有两位数, 因为每次求出来的只能是b的一个数字
AC代码
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef pair<int,int> PII;
const int N = 1e6+10;
int a[N];
int main()
{
int t;
cin >> t;
while(t --)
{
string s, a;
bool f = 1;
stack<int> c;
cin >> a >>s;
for(int i = a.size()-1, j = s.size()-1; j >= 0; i --, j --)
{ int aa = i>=0?a[i]-'0':0;
int ss = s[j]-'0';
if(ss<aa)
{
if(j==0)
{f=0; break;}//这里是防止下面越界
ss =( s[--j]-'0')*10 + ss;
if(ss<aa){f=0; break;}
}
if(ss-aa>=10){f=0; break;}//减去后有两位数
c.push(ss-aa);
if(j==0&&i>j){f=0; break;}
}
if(!f)puts("-1");
else
{
LL x = 0;
while(c.size())
{
x=(LL)c.top()+x*(LL)10;
c.pop();
}
cout << x<<'\n';
} } return 0;
}
D. New Year's Problem
题意
输入顺序是先m后n
张三有 n 个朋友,要在 m 个商店中选一些商店给他的朋友买礼物(最多选n − 1个商店),要求每个朋友都要收到礼物。
要求最大化 min(每个朋友获得的礼物价值)
题解--二分
对于每个商店--行 : 至少有一个店有两个 礼物>=所枚举的mid, 且最后礼物>=所枚举的mid的礼物总数>=n
对于每个朋友--列 : 每个朋友至少有一个礼物
符合以上条件check函数就完成了
本题学到了对于n*m<=2e5存储的刁钻方法
vector<vector<int> > a(m, vector<int>(n));//定义
bool check(int x, vector<vector<int>> &a)//传入地址
AC代码
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef pair<int,int> PII;
const int N = 2e5+10;
int m, n; bool check(int x, vector<vector<int>> &a)
{
int ff=0;int f = 0;
for(int i = 0; i < m; i ++)
{
int b=0;
for(int j = 0; j < n; j ++)
{
if(a[i][j]>=x)f ++, b++;
}
if(b>1)ff=1;
}
if(!ff || f<n)return 0; for(int j = 0; j < n; j ++)
{
int f = 0;
for(int i = 0; i < m; i ++)
{
if(a[i][j]>=x)f ++;
}
if(!f)return 0;
}
return 1;
} int main()
{
int t;
cin >> t;
while(t --)
{ cin >> m >> n;
vector<vector<int> > a(m, vector<int>(n));
for(int i = 0; i < m; i ++)
for(int j = 0; j <n; j ++)
cin>> a[i][j]; int l = 0, r = 1e9;
while(l < r)
{
int mid = l+r+1>>1;
if(check(mid, a))l = mid;
else r = mid-1;
}
cout <<l<<endl;
} return 0;
}
E. MEX and Increments(比D简单)
题意
给一串数, 求出当mex=0~n是需要的最小操作数
每一操作可以选择一个数+1, 注: mex=数组中未包含的最小非负整数
题解
对于mex=i时, 输出=数组内i的个数+x
x=补齐1~i-1所需的操作数
多余的数放入优先队列就行了, 每次出来最大的数, 这样差值最小
本题又复习了优先队列好耶!
priority_queue<int, vector<int>> heap;//大到小
priority_queue<int, vector<int>, greater<int>> heap;//小到大
AC代码
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N = 2e5+10;
int a[N], b[N], c[N]; int main(){
int t;
cin >> t;
while(t --)
{
int n;
cin >> n;
for(int i = 0;i <= n ; i++) b[i]=0;
for(int i = 0;i < n ; i++) cin >> a[i], b[a[i]]++;
sort(a,a+n);
priority_queue<int, vector<int>> heap; bool f = 0;
LL x=0, y=0;
for(int i = 0; i <= n; i ++)
{
if(i && y<i)
{
f = 1;
for(int j = i; j <= n; j ++)cout <<"-1 ";
break;
}
else
{ if(a[i]<=i)
y++;
if(i && b[i-1]==0)
{
int t = heap.top();
heap.pop();
x += i-1-t;
}
if(b[i]>1)
for(int j = 2; j <= b[i]; j ++)heap.push(i);//多余的数进队
cout << x+b[i]<<' ';
}
}
cout << endl;
}
return 0;
}
Codeforces Round #762 (Div. 3), CDE的更多相关文章
- Codeforces Round #542(Div. 2) CDE 思维场
C https://codeforces.com/contest/1130/problem/C 题意 给你一个\(n*m\)(n,m<=50)的矩阵,每个格子代表海或者陆地,给出在陆地上的起点终 ...
- Codeforces Round #415 (Div. 1) (CDE)
1. CF 809C Find a car 大意: 给定一个$1e9\times 1e9$的矩阵$a$, $a_{i,j}$为它正上方和正左方未出现过的最小数, 每个询问求一个矩形内的和. 可以发现$ ...
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- Codeforces Round #279 (Div. 2) ABCDE
Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems # Name A Team Olympiad standard input/outpu ...
- Codeforces Round #262 (Div. 2) 1003
Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...
- Codeforces Round #262 (Div. 2) 1004
Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...
随机推荐
- 阿里云pypi软件包预警
镜像下载.域名解析.时间同步请点击阿里云开源镜像站 背景 Python库的官方仓库pypi允许开发者自由上传软件包,这会导致某些攻击者利用这点构造恶意包进行供应链攻击,在用户安装包或者引入包时触发恶意 ...
- 领域驱动模型DDD(一)——服务拆分策略
前言 领域驱动模型设计在业界也喊了几年口号了,但是对于很多"务实"的程序员来说,纸上谈"术"远比敲代码难得太多太多.本人能力有限,在拜读相关作品时既要隐忍书中晦 ...
- 『忘了再学』Shell基础 — 5、Bash基本功能(命令的别名和常用快捷键)
目录 1.给命令设置别名 (1)设置别名的命令格式 (2)命令别名永久生效 (3)别名的优先级 2.Bash常用快捷键 1.给命令设置别名 Linux系统的命令别名我们之前已经说过了,这里再过一边. ...
- tomcat 部署war,umask上传文件后无法通过nginx反向代理访问上传后的文件
Catalina.sh文件,把umask修改为 0022 即可. 引用:https://tomcat.apache.org/tomcat-8.5-doc/security-howto.html
- zookeeper的通知机制
一.znode Zookeeper维护一个类似文件系统的数据结构.简单来说,有点类似windows中注册表的结构,有名称,有树节点,有Key(键)/Value(值)对的关系,可以看做一个树形结构的数据 ...
- C# winform自己的窗体不抢夺其他窗体的光标
在你的form里加入: protected override CreateParams CreateParams { get { var result = base.CreateParams; ; r ...
- CAN总线系列讲座第六讲——SJA1000的滤波器设置
CAN总线的滤波器设置就像给总线上的节点设置了一层过滤网,只有符合要求的CAN信息帧才可以通过,其余的一概滤除. 在验收滤波器的帮助下,只有当接收信息中的识别位和验收滤波器预定义的值相等时,CAN 控 ...
- 在网页中预览excel表格文件
项目需求在前端页面中实现预览excel表格的功能,上网了解之后大致总结为一下几种方法. 1.office文档转换为pdf,再转swf,然后通过网页加载flash进行预览 2.通过 xlsx.js,js ...
- JS:数组中push对象,覆盖问题
发现将对象push进数组,后面的值会覆盖前面的值,最后输出的都是最后一次的值.其实这一切都是引用数据类型惹的祸.如果你也有类似问题,可以继续看下去哦.下面代码模拟:将json对象的每个键值对,单独搞成 ...
- Day05 - Flex 实现可伸缩的图片墙 中文指南
Day05 - Flex 实现可伸缩的图片墙 中文指南 作者:liyuechun 简介:JavaScript30 是 Wes Bos 推出的一个 30 天挑战.项目免费提供了 30 个视频教程.30 ...