Codeforces Round 582

这次比赛看着是Div.3就打了,没想到还是被虐了,并再次orz各位AK的大神……

A. Chips Moving

签到题。(然而签到题我还调了20min……)

因为数据小,所以像我一样打模拟也可以,但其实只要统计一下奇数偶数的个数并输出较小的一个即可。

#include<bits/stdc++.h>

using namespace std;

int n;
long long ans=0x3f3f3f3f;
int a[110]; void Read() {
scanf("%d",&n);
for(int i=1;i<=n;i++) {
scanf("%d",&a[i]);
}
return;
} int main()
{
Read();
for(int i=1;i<=n;i++) {
long long tmp=0;
for(int j=1;j<=n;j++) {
if(abs(a[j]-i)%2==1) {
tmp++;
}
}
ans=min(ans,tmp);
}
printf("%lld",ans);
return 0;
}

B. Bad Prices

(题目中的Polycarp真是太有经济头脑了,自己作为买家还希望卖家不要亏本……)

这道题本来也想来个暴力模拟,结果第一次提交成功在第三个点上T掉;后来优化了一下数组,第二次提交还是第三个点T掉。后来想到只要维护一个后缀最小值数组,即从最后一天到第$n$天中价格的最小值。若第$n$天的价格大于第$n$天的后缀最小值,那就是一个"Bad Price"。

#include<bits/stdc++.h>

using namespace std;

int t,n,ans;
int a[150010],pre[150010]; void Init() {
n=0;
ans=0;
memset(a,0,sizeof(a));
memset(pre,0x7f,sizeof(pre));
return;
} void Read()
{
scanf("%d",&n);
for(int i=1;i<=n;i++) {
scanf("%d",&a[i]);
}
return;
} void findMin() {
for(int i=n;i>=1;i--) {
pre[i]=min(pre[i+1],a[i]);
}
return;
} void Solve() {
for(int i=1;i<=n;i++) {
if(a[i]>pre[i]) {
ans++;
}
}
printf("%d\n",ans);
return;
} int main()
{
scanf("%d",&t);
for(int i=1;i<=t;i++) {
Init();
Read();
findMin();
Solve();
}
return 0;
}

C. Book Reading

这题只用统计$m$倍数的个位数字之和,继续打模拟,结果连样例都跑不出来……

一看样例:

1234312817382646 13

顿时醒悟……当$n$远大于$m$时,$n\div m$的值会很大,以至于1s根本跑不完。

于是我就在这卡了将近1h……(在此期间尝试调了下D1,结果发现根本没思路)

在临近比赛结束前15min,忽然灵光一闪,既然只统计个位数字,取值就只有$0$-$9$共十种,那为什么不……打表呢?

于是经过一番简单的运算,这道题就……A了。

#include<bits/stdc++.h>

using namespace std;

int q,lownum;
long long n,m,ans; int main()
{
scanf("%d",&q);
for(int i=1;i<=q;i++) {
ans=0;
long long div=0,mod=0;
scanf("%lld%lld",&n,&m);
div=n/m;
mod=div%10;
div-=mod;
div/=10;
switch(m%10) {
case 0:
ans=0;
break;
case 1:
ans=div*45;
for(int j=1;j<=mod;j++) {
ans+=(j*1)%10;
}
break;
case 2:
ans=div*40;
for(int j=1;j<=mod;j++) {
ans+=(j*2)%10;
}
break;
case 3:
ans=div*45;
for(int j=1;j<=mod;j++) {
ans+=(j*3)%10;
}
break;
case 4:
ans=div*40;
for(int j=1;j<=mod;j++) {
ans+=(j*4)%10;
}
break;
case 5:
ans=div*25;
for(int j=1;j<=mod;j++) {
ans+=(j*5)%10;
}
break;
case 6:
ans=div*40;
for(int j=1;j<=mod;j++) {
ans+=(j*6)%10;
}
break;
case 7:
ans=div*45;
for(int j=1;j<=mod;j++) {
ans+=(j*7)%10;
}
break;
case 8:
ans=div*40;
for(int j=1;j<=mod;j++) {
ans+=(j*8)%10;
}
break;
case 9:
ans=div*45;
for(int j=1;j<=mod;j++) {
ans+=(j*9)%10;
}
break;
}
printf("%lld\n",ans);
}
return 0;
}

当然还是要提一下正解的思路的。

令$k=[\frac nm]$是从$1$到$n$的整数个数,可被$m$整除。我们可以注意到,因为我们只记下每个可被$m$整除的数字的最后一位数字,所以数字“周期”的长度不超过$10$。事实上,我们总是可以假设它是$10$,因为对于从0到9的所有$i$,都有$i\times m\equiv(10+i)\times m\ (mod\ 10)$。所以对于从$0$到$9$的所有$i$,使$cycle_i=m\times (i+1)\ mod\ 10$,然后答案是$[\frac k{10}]\sum_{i=0}9cycle_i+\sum_{i=0}{k\ mod\ 10}cycle_i$.

D. Equalizing by Division

这题就是分为两个难度,我调了一下easy的,但发现思路基本是错的,然后就放弃了……

至于Hard的……就以后再说吧。

E. Two Small Strings

F. Unstable String Sort

G. Path Queries

总之,以后还是要多刷题,多打比赛,多多听从老师教诲……

Codeforces Round 582的更多相关文章

  1. Codeforces Round #582 (Div. 3)-G. Path Queries-并查集

    Codeforces Round #582 (Div. 3)-G. Path Queries-并查集 [Problem Description] 给你一棵树,求有多少条简单路径\((u,v)\),满足 ...

  2. Codeforces Round #582 (Div. 3)

    题目链接:https://codeforces.com/contest/1213 A: 题意:给定数的位置,位置为整数,每个数可以向左或右移动一格或者两格,移动一格花费一个硬币,两格不花费硬币,问所有 ...

  3. Codeforces Round #582 (Div. 3) G. Path Queries (并查集计数)

    题意:给你带边权的树,有\(m\)次询问,每次询问有多少点对\((u,v)\)之间简单路径上的最大边权不超过\(q_i\). 题解:真的想不到用最小生成树来写啊.... 我们对边权排序,然后再对询问的 ...

  4. Codeforces Round #582 (Div. 3) E. Two Small Strings (构造,思维,全排列)

    题意:给你两个长度为\(2\)的字符串\(s\)和\(t\),你需要构造一个长度为\(3n\)的字符串,满足:含有\(n\)个\(a\),\(n\)个\(b\),\(n\)个\(c\),并且\(s\) ...

  5. Codeforces Round #582 (Div. 3) A. Chips Moving

    传送门 题解: 给你n个数的坐标,你需要把他们移动到一个位置,有两种移动方式 1.向左或者右移动2 2.向左或者右移动1,但是耗费1 求最小耗费 题解: 很简单就可以想到,看一下偶数坐标多还是奇数坐标 ...

  6. Codeforces Round #582 (Div. 3) C. Book Reading

    传送门 题意: 给你n,k.表示在[1,n]这个区间内,在这个区间内找出来所有x满足x%k==0,然后让所有x的个位加到一起(即x%10),输出. 例如:输入10 2 那么满足要求的数是2 4 6 8 ...

  7. Codeforces Round #582 (Div. 3) F. Unstable String Sort

    传送门 题意: 你需要输出一个长度为n的字符序列(由小写字母组成),且这个字符串中至少包含k个不同的字符.另外题目还有要求:给你两个长度为p和q的序列,设字符序列存在s中 那么就会有s[Pi]< ...

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

  9. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

随机推荐

  1. 【redis】 windows 32x 64x

    下载地址:http://files.cnblogs.com/files/dtdxrk/redis_win.zip

  2. 微信API V3 RESTFUL

    {"code":"SIGN_ERROR","message":"商户未设置加密的密钥,请登录商户平台操作!请参考http://kf ...

  3. 如何解决mac brew遇到无法下载的依赖?

    使用brew安装软件时,需要下载依赖包,但是如果依赖包特别大的时候,就很容易失败:brew本身不支持断点续传:但是可以使用wget -c的方式断点续传的下载依赖:下载完如何给brew安装使用呢?参考: ...

  4. 【GStreamer开发】GStreamer播放教程09——数字音频传输

    目标 本教程展示GStreamer是如何进行数字音频传输的. 介绍 在常见的模拟格式外,高端的音频系统通常都接受数字格式,压缩的非压缩的都能接受.因为音频信号是从电脑传到音箱,用一种更有弹性的形态会更 ...

  5. 什么?Iconfont终于可以支持彩色图标了

    如果你对iconfont有所了解,那你一定对这次iconfont做出的更新产生兴趣.没错,iconfont目前已经升级为iconfont+,并且能够支持大家都很期待的彩色图标. 之前,大家也以文字的形 ...

  6. 洛谷 题解 P2540 【斗地主增强版】

    [分析] 暴力搜顺子,贪心出散牌 为什么顺子要暴力? 玩过斗地主的都知道,并不是出越长的顺子越好,如果你有一组手牌,3,4,5,6,7,6,7,8,9,10,你一下把最长的出了去,你会单两张牌,不如出 ...

  7. springboot之Redis

    1.springboot之Redis配置 在学习springboot配置Redis之前先了解Redis. 1.了解Redis Redis简介: redis是一个key-value存储系统.和Memca ...

  8. AVR单片机教程——流水灯

    上次我们用 delay 函数与 while 循环实现了一个LED的闪烁.这一次我们把所有LED加入进来,让它们依次闪烁,形成流水灯的效果. 开发板上有4个LED,我们可以用不多的语句把循环体直接描述出 ...

  9. uwsgi flask gevent 测试代码覆盖率(coverage)

    目录 可能出现的问题 解决 可能出现的问题 多进程启动 gevent启动 运行的服务可能不会停止 解决 我先参考了一下这一篇文章使用Coverage分析WSGI项目的代码覆盖率,他基本能够解决掉1.2 ...

  10. Scratch编程:躲开鲨鱼(五)

    “ 上节课的内容全部掌握了吗?反复练习了没有,编程最好的学习方法就是练习.练习.再练习.一定要记得多动手.多动脑筋哦~~” 01 — 游戏介绍 这是一款简单的小游戏,实现了用鼠标控制一条小海星在水里游 ...