Codeforces Round #451 (Div. 2) A B C D E
Codeforces Round #451 (Div. 2)
A Rounding
题目链接:
http://codeforces.com/contest/898/problem/A
思路:
小于等于5向下,大于补上差值输出
代码:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main() {
ll n;
scanf("%I64d",&n);
int r=n%10;
if(r<=5) printf("%I64d\n",n-r);
else printf("%I64d\n",n+10-r);
return 0;
}
B Proper Nutrition
题目链接:
http://codeforces.com/contest/898/problem/B
思路:
暴力枚举
代码:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main() {
ll a,b,n;
scanf("%I64d",&n);
scanf("%I64d %I64d",&a,&b);
bool flag=false;
ll index=n/a;
for(ll i=0;i<=index;++i) {
ll temp=n-i*a;
if(temp/b*b==temp) {
printf("YES\n");
printf("%I64d %I64d\n",i,temp/b);
flag=true;
break;
}
}
if(!flag) printf("NO\n");
return 0;
}
C Phone Numbers
题目链接:
http://codeforces.com/contest/898/problem/C
思路:
暴力大法。
就是string排序的时候重写一下cmp,另外sort之后不要unique,不然会wa5
代码:
#include <bits/stdc++.h>
using namespace std;
vector<string> vec[21];
map<int,string> mp;
set<string> se;
bool cmp(string a, string b) {
if(a.length()!=b.length()) return a.length()<b.length();
return a<b;
}
int main() {
ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int n,cnt,id;cin>>n;
string name;
int tot;
string number;
cnt=1;
for(int i=0;i<n;++i) {
cin>>name;
cin>>tot;
if(se.count(name)==0) {
mp[cnt]=name;
se.insert(name);
++cnt;
}
for(auto it=mp.begin();it!=mp.end();it++) {
if(it->second==name) {
id=it->first;
break;
}
}
for(int j=0;j<tot;++j) {
cin>>number;
vec[id].push_back(number);
}
}
cout<<se.size()<<endl;
for(int i=1;i<cnt;++i) {
sort(vec[i].begin(),vec[i].end(),cmp);
for(unsigned int j=0;j<vec[i].size();++j) {
string s;
s=vec[i][j];
reverse(s.begin(),s.end());
for(unsigned int z=j+1;z<vec[i].size();++z) {
string ss;
ss=vec[i][z];
reverse(ss.begin(),ss.end());
if(ss.substr(0,s.length())==s) {
vec[i].erase(vec[i].begin()+j);
--j;
break;
}
}
}
cout<<mp[i]<<" "<<vec[i].size()<<" ";
for(unsigned int j=0;j<vec[i].size();++j) {
if(j>0) cout<<" "<<vec[i][j];
else cout<<vec[i][j];
}
cout<<endl;
}
return 0;
}
D Alarm Clock
题目链接:
http://codeforces.com/contest/898/problem/D
题目大意:
不允许在m分钟内有k个闹钟响,每个闹钟响一分钟,求最少关掉的闹钟数目
思路:
首先其实按照从小到大的时间顺序查看,因为这相当于一个m大的滑块在整个数组上划一遍,所以使用队列就可以,其实就是贪心的思想。
代码:
#include <bits/stdc++.h>
using namespace std;
const int maxn = 1000005;
int a[maxn];
int main() {
int n,m,k,num,res=0,tot=0;
scanf("%d %d %d",&n,&m,&k);
for(int i=1;i<=n;++i) a[i]=0;
for(int i=1;i<=n;++i) scanf("%d",&num),a[num]=1;
for(int i=1;i<=1e6;++i) {
if(a[i]) ++tot;
if(i>m&&a[i-m]) --tot;
if(tot==k) {
--tot;
++res;
a[i]=0;
}
}
printf("%d\n",res);
return 0;
}
E Squares and not squares
题目链接:
http://codeforces.com/contest/898/problem/E
思路:
统计出给定序列的完全平方数和非完全平方数,看看是要补平方数还是补非完全平方数。记录下每个数距离最近的完全平方数的插值,同时记录下改为非完全平方数的最小差值。根据是前面所述的两种情况中的一种进行排序,选择出最小的数据插值求和即可。
代码:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 200005;
struct node {ll num,a,b;int d;}ans[maxn];
bool cmp1(node x, node y) {return x.a<y.a;}
bool cmp2(node x, node y) {return x.b<y.b;}
int main() {
int n;scanf("%d",&n);
int d1,d2,cnt;
ll sum=0;
d1=0;
for(int i=0;i<n;++i) {
scanf("%I64d",&ans[i].num);
ll number=(ll)sqrt(ans[i].num);
ll x=number*number;
if(x==ans[i].num) {
++d1;
ans[i].d=1;
} else ans[i].d=0;
ll y=(number+1)*(number+1);
ans[i].a=min(ans[i].num-x,y-ans[i].num);
if(max(ans[i].num-x,y-ans[i].num)>1) ans[i].b=1;
else ans[i].b=2;
}
d2=n-d1;
if(d2>d1) {
cnt=n/2-d1;
sort(ans,ans+n,cmp1);
for(int i=0;i<n;++i) {
if(ans[i].a!=0&&ans[i].d==0) {
sum+=ans[i].a;
--cnt;
if(cnt==0) break;
}
}
} else if(d1>d2) {
cnt=n/2-d2;
sort(ans,ans+n,cmp2);
for(int i=0;i<n;++i) {
if(ans[i].b!=0&&ans[i].d==1) {
sum+=ans[i].b;
--cnt;
if(cnt==0) break;
}
}
}
printf("%I64d\n",sum);
return 0;
}
Codeforces Round #451 (Div. 2) A B C D E的更多相关文章
- Codeforces Round #451 (Div. 2)-898A. Rounding 898B.Proper Nutrition 898C.Phone Numbers(大佬容器套容器) 898D.Alarm Clock(超时了,待补坑)(贪心的思想)
A. Rounding time limit per test 1 second memory limit per test 256 megabytes input standard input ou ...
- Codeforces Round #451 (Div. 2) A. Rounding【分类讨论/易错】
A. Rounding time limit per test 1 second memory limit per test 256 megabytes input standard input ou ...
- Codeforces Round #451 (Div. 2) [ D. Alarm Clock ] [ E. Squares and not squares ] [ F. Restoring the Expression ]
PROBLEM D. Alarm Clock 题 OvO http://codeforces.com/contest/898/problem/D codeforces 898d 解 从前往后枚举,放进 ...
- Codeforces Round #451 (Div. 2)
水题场.... 结果因为D题看错题意,B题手贱写残了...现场只出了A,C,E A:水题.. #include<bits/stdc++.h> #define fi first #defin ...
- Codeforces Round #451 (Div. 2) B. Proper Nutrition【枚举/扩展欧几里得/给你n问有没有两个非负整数x,y满足x·a + y·b = n】
B. Proper Nutrition time limit per test 1 second memory limit per test 256 megabytes input standard ...
- 【Codeforces Round #451 (Div. 2) A】Rounding
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 模拟 [代码] /* 1.Shoud it use long long ? 2.Have you ever test several ...
- 【Codeforces Round #451 (Div. 2) B】Proper Nutrition
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 可以直接一层循环枚举. 也可以像我这样用一个数组来存y*b有哪些. 当然.感觉这样做写麻烦了.. [代码] /* 1.Shoud i ...
- 【Codeforces Round #451 (Div. 2) C】Phone Numbers
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 用map<string,vector > dic;模拟就好. 后缀.翻转一下就变成前缀了. 两重循环剔除这种情况不输出就 ...
- 【Codeforces Round #451 (Div. 2) D】Alarm Clock
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 尺取法+二分. 类似滑动窗口. 即左端点为l,右端点为r. 维护a[r]-a[l]+1总是小于等于m的就好. (大于m就右移左端点) ...
随机推荐
- Mybatis:CRUD操作
提示: Mapper配置文件的命名空间为对应接口包名+接口名字,这个经常会忘记和搞错的!! select标签 在接口中编写三个查询方法 //获取全部用户List<User> selectU ...
- ThinkPHP5.1 反序列化利用链
笔记里直接复制出来的 1 composer直接获取框架代码 ➜ composer create-project --prefer-dist topthink/think tp5137 ➜ ...
- No such application config! Please add dubbo:application
SpringBoot运行找不到application.properties配置文件 运行springBoot项目启动报错:java.lang.IllegalStateException: No suc ...
- 二、安装JDK - Java软件的安装
jdk是 Java 语言的软件开发工具包,主要用于移动设备.嵌入式设备上的java应用程序. 1.安装包的下载:http://pan.baidu.com/s/1mgh58ve (该安装包是绿色的,解压 ...
- 如何利用缓存机制实现JAVA类反射性能提升30倍
一次性能提高30倍的JAVA类反射性能优化实践 文章来源:宜信技术学院 & 宜信支付结算团队技术分享第4期-支付结算部支付研发团队高级工程师陶红<JAVA类反射技术&优化> ...
- 关于数论分块里r=sum/(sum/l)的证明!
今天的模拟赛里T2要使用到数论分块,里面有一个重要的坎就是关于r=sum/(sum/l)的证明,网上关于这道题的题解里都没有关于这个的证明,那么我就来填补一下: 在以下的文章里,我都会使用lo(x)表 ...
- ARM7中断的理解
谈谈对中断的理解? 中断是计算机中处理异步事件的重要机制 中断触发的方式: 1)中断源级设置 按键:(CPU之外的硬件) 设置中 ...
- node.js评论列表和添加购物车数据库表创建
2.1:评论列表--发表评论 用户点击新闻列表某一条新闻,看到新闻详细发表评论 -用户输入评论内容 -发表评论 [将用户评论内容保存数据库 xz_comment] 2.2:评论列表--发表评论-开发评 ...
- SD-WAN 本地策略与中心策略配置(三)
目录 1. Localized Policy配置 2. Centralized Policy配置 3. Application Route and Traffice Policy 1. Localiz ...
- Java把一个文件,输出成多个文件
前言:我有一个出租车轨迹的txt文本,其中包括多条轨迹.我想把这个文本按照单条轨迹输出出来,每条轨迹放在一个txt文本中. 思路:重要问题就集中在,如何动态的指定输出文件的名字.我想到了StringB ...