Codeforces Round #460 (Div. 2) ABCDE题解
原文链接http://www.cnblogs.com/zhouzhendong/p/8397685.html
2018-02-01
$A$
题意概括
你要买$m$斤水果,现在有$n$个超市让你选择。
每个超市的水果价格是固定的。第$i$个超市的水果价格用两个整数$a_i和b_i$来表示。含义是$a_i$元可以买$b_i$斤。
问你买$m$斤水果最少花费多少钱。
题解
直接枚举超市,判断最少的花费就可以了。
代码
#include <cstring>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <algorithm>
using namespace std;
const int N=5005;
int n;
double m,ans=1e100;
int main(){
scanf("%d%lf",&n,&m);
for (int i=1;i<=n;i++){
int a,b;
scanf("%d%d",&a,&b);
ans=min(ans,m*a/b);
}
printf("%.10lf",ans);
return 0;
}
$B$
题意概括
找第$k$个各个数位之和为 10 的正整数。($k<=10000$)
题解
从1开始暴搜即可。每次把各个数位加起来判断一下就可以了。实测$k=10000$的时候大约答案为一千万左右。
代码
#include <cstring>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <cstdlib>
using namespace std;
int k,ans=0;
bool check(int v){
int res=0;
while (v){
res+=v%10,v/=10;
if (res>10)
break;
}
return res==10;
}
int main(){
scanf("%d",&k);
while (k-=check(++ans));
printf("%d",ans);
return 0;
}
$C$
题意概括
给一个$n \times m$的矩阵,里面'.'表示空,'*'表示有人,问你有多少个不同的$1 \times k$的全空矩阵。
1<=n,m,k<=2000
题解
我们分每行每列分别枚举,每个前缀'.'大于等于k的格子贡献为1.
然而本题有坑点,不少$hacker$借此大赚一把。
当$k=1$的时候,答案要除以2!!!
代码
#include <cstring>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <cstdlib>
using namespace std;
const int N=2005;
int n,m,k;
char g[N][N];
int main(){
scanf("%d%d%d",&n,&m,&k);
for (int i=1;i<=n;i++)
scanf("%s",g[i]+1);
int ans=0;
for (int i=1;i<=n;i++){
int cnt=0;
for (int j=1;j<=m;j++){
if (g[i][j]=='.')
cnt++;
else
cnt=0;
if (cnt>=k)
ans++;
}
}
for (int i=1;i<=m;i++){
int cnt=0;
for (int j=1;j<=n;j++){
if (g[j][i]=='.')
cnt++;
else
cnt=0;
if (cnt>=k)
ans++;
}
}
if (k==1)
ans/=2;
printf("%d",ans);
return 0;
}
$D$
题意概括
有一个有$n$个节点,$m$条边的有向图,每一个节点i上面有一个字母$a_i$。
定义一条路径的价值为经过的所有节点中遇到的出现次数最多的字母的出现次数。
现在问你价值最大的路径的价值。(如果价值为$\infty$,输出$-1$)
$ 1 <= n,m <= 300000 , 'a'<= a_i <= 'z' $
题解
首先考虑 $-1$ 的情况。
显然,只要有环就是 $-1$,所以这个可以实现判掉。
于是剩下来的就是一个$DAG$了。
那么显然,由于字母只有26个,那么我们只需要拓扑排序 + $DP$就可以了。
具体怎么DP看代码。
代码
#include <cstring>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <cstdlib>
using namespace std;
const int N=300005,M=300005;
struct Gragh{
int cnt,y[M],nxt[M],fst[N];
void clear(){
cnt=0;
memset(fst,0,sizeof fst);
}
void add(int a,int b){
y[++cnt]=b,nxt[cnt]=fst[a],fst[a]=cnt;
}
}g;
int n,m,v[N],vis[N];
int in[N],q[N],head,tail,dp[N][26];
char s[N];
bool dfs_round(int x,int mark){
if (vis[x])
return vis[x]==mark&&in[x];
vis[x]=mark;
in[x]=1;
for (int i=g.fst[x];i;i=g.nxt[i])
if (dfs_round(g.y[i],mark))
return 1;
in[x]=0;
return 0;
}
bool round(){
memset(vis,0,sizeof vis);
memset(in,0,sizeof in);
int mark=0;
for (int i=1;i<=n;i++)
if (!vis[i])
if (dfs_round(i,++mark))
return 1;
return 0;
}
int main(){
scanf("%d%d%s",&n,&m,s+1);
for (int i=1;i<=n;i++)
v[i]=s[i]-'a';
g.clear();
for (int i=1;i<=m;i++){
int a,b;
scanf("%d%d",&a,&b);
g.add(a,b);
}
if (round()){
puts("-1");
return 0;
}
memset(dp,0,sizeof dp);
memset(in,0,sizeof in);
for (int i=1;i<=m;i++)
in[g.y[i]]++;
head=tail=0;
for (int i=1;i<=n;i++)
if (!in[i])
q[++tail]=i;
int ans=0;
while (head<tail){
int x=q[++head];
dp[x][v[x]]++;
for (int i=0;i<26;i++)
ans=max(ans,dp[x][i]);
for (int i=g.fst[x];i;i=g.nxt[i]){
int y=g.y[i];
for (int j=0;j<26;j++)
dp[y][j]=max(dp[y][j],dp[x][j]);
if (!--in[y])
q[++tail]=y;
}
}
printf("%d",ans);
return 0;
}
$E$
题意概括
问有多少个n满足以下条件:
$ 1<=n<=x $
$ n \cdot a^n \equiv b (mod \; p) $
输入$a b p x$,保证$p$是素数。
2 ≤ p ≤ 106 + 3, 1 ≤ a, b < p, 1 ≤ x ≤ 1012
题解
由于p为素数,根据费马小定理,$ a^k \equiv a^{k+(p-1)} (mod \; p) $
于是我们可以从$1$ ~ $p-1$枚举$n \bmod (p-1)$的值。
然后对于一个解$n\;mod\;(p-1) = i$,我们考虑到$a^n \equiv a^i (mod \; p )$, 所以,可以得到$n \equiv \frac{b}{a^i} (mod \; p)$
即$n \equiv b \times inv(a^i) (mod \; p)$
设$ x=i \; mod \; (p-1),\; y=b \times inv(a^i) \; mod \; p$,则有如下两个方程:
$n \equiv x\;(mod\;(p-1))$
$n \equiv y\;(mod\;p)$
这个讲道理有中国剩余定理(CRT)合并,但是实际上我们只需要瞎凑就可以了。
凑出来,$n\equiv -(p-1)\times y\; + \; p \times x (mod \; (p(p-1)))$
于是我们得到了关于$n$的一般形式,那么计算他的贡献就很轻松了(这个不讲了,直接看代码吧),总共$p-1$种$n$的形式,每个的贡献相加即答案。
代码
#include <cstring>
#include <cmath>
#include <cstdlib>
#include <cstdio>
#include <algorithm>
using namespace std;
typedef long long LL;
const int P=1e6+10;
LL a,b,p,x,inv[P];
LL Pow(LL x,LL y){
if (!y)
return 1;
LL xx=Pow(x,y/2);
xx=xx*xx%p;
if (y&1LL)
xx=xx*x%p;
return xx;
}
LL Inv(LL x){
return Pow(x,p-2);
}
int main(){
scanf("%I64d%I64d%I64d%I64d",&a,&b,&p,&x);
for (LL i=1;i<p;i++)
inv[i]=Inv(i);
LL ans=0;
for (LL i=1;i<p;i++){
LL y=b*inv[Pow(a,i)]%p;
// n=y (mod p)
// n=i (mod p-1)
// n=up+y=v(p-1)+i
// n=kp(p-1) - (p-1)*y + p*i
LL mod=p*(p-1),n=(p*i%mod-(p-1)*y%mod+mod-1)%mod+1;
if (n<=x)
ans+=(x-n)/mod+1;
}
printf("%I64d",ans);
return 0;
}
Codeforces Round #460 (Div. 2) ABCDE题解的更多相关文章
- Codeforces Round #546 (Div. 2) ABCDE 题解
1136A: 题意:一本书有n个章节,每个章节的分别在li到ri页,小明读完书后将书折在第k页,问还有多少章节没有读 题解:控制k在li~ri的范围内后输出n-i即可 #include <set ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- Codeforces Round #261 (Div. 2)[ABCDE]
Codeforces Round #261 (Div. 2)[ABCDE] ACM 题目地址:Codeforces Round #261 (Div. 2) A - Pashmak and Garden ...
- # Codeforces Round #529(Div.3)个人题解
Codeforces Round #529(Div.3)个人题解 前言: 闲来无事补了前天的cf,想着最近刷题有点点怠惰,就直接一场cf一场cf的刷算了,以后的题解也都会以每场的形式写出来 A. Re ...
- Codeforces Round #557 (Div. 1) 简要题解
Codeforces Round #557 (Div. 1) 简要题解 codeforces A. Hide and Seek 枚举起始位置\(a\),如果\(a\)未在序列中出现,则对答案有\(2\ ...
- Codeforces Round #540 (Div. 3) 部分题解
Codeforces Round #540 (Div. 3) 题目链接:https://codeforces.com/contest/1118 题目太多啦,解释题意都花很多时间...还有事情要做,就选 ...
- Codeforces Round #538 (Div. 2) (A-E题解)
Codeforces Round #538 (Div. 2) 题目链接:https://codeforces.com/contest/1114 A. Got Any Grapes? 题意: 有三个人, ...
- Codeforces Round #531 (Div. 3) ABCDEF题解
Codeforces Round #531 (Div. 3) 题目总链接:https://codeforces.com/contest/1102 A. Integer Sequence Dividin ...
- Codeforces Round #527 (Div. 3) ABCDEF题解
Codeforces Round #527 (Div. 3) 题解 题目总链接:https://codeforces.com/contest/1092 A. Uniform String 题意: 输入 ...
随机推荐
- HDU 1796 (容斥原理)
容斥原理练习题,忘记处理gcd 和 lcm,wa了几发0.0. #include<iostream> #include<cstdio> #include<cstring& ...
- [C]gcc编译器的一些常用语法
简单的GCC语法: 如果你只有一个文件(或者只有几个文件),那么就可以不写Makefile文件(当然有Makefile更加方便),用gcc直接编译就行了.在这里我们只介绍几个我经常用的几个参数,第一是 ...
- C# 如何获取自定义的config中节点的值,并修改节点的值
现定义一个方法 DIYConfigHelper.cs using System; using System.Xml; using System.Configuration; using System. ...
- 用docker快速搭建wordpress博客
WordPress是一个非常著名的PHP编写的博客平台,发展到目前为止已经形成了一个庞大的网站平台系统.在WP上有规模庞大的插件和主题,可以帮助我们快速建立一个博客甚至网站. 在Windows上可 ...
- Android:四大架构的优缺点,你真的了解吗?
声明|转载于作者:KunMinX原文链接:https://www.jianshu.com/p/9ef813d5c1af 前言 前不久刚结束对 20 模块项目的第 3 轮重构,一路见证 MVC.MVP. ...
- Java的家庭记账本程序(B)
日期:2019.2.3 博客期:029 星期日 看看今天想先完成jsp的连接操作,所以首先意识到自己的程序中,管理员可以对成员进行冻结.解封操作,所以先回去补了一下数据库的内容!成员的内容里多了一项i ...
- ionic3 更新打开apk android 8.0报错
项目中安卓强制更新,当文件下载完.在android 8.0中不能打开apk包. 引入插件报一下错误 import { FileOpener } from '@ionic-native/file-ope ...
- 水果(map的嵌套)
夏天来了~~好开心啊,呵呵,好多好多水果~~ Joe经营着一个不大的水果店.他认为生存之道就是经营最受顾客欢迎的水果.现在他想要一份水果销售情况的明细表,这样Joe就可以很容易掌握所有水果的销售情况了 ...
- swoole 使用异步redis的前置条件
redis安装 官网下载redis 下载完成之后解压: 进入redis目录执行make: 进入src目录启动redis 启动成功如下: 启动后连接redis 编译安装hiredis 下载:https: ...
- noip 2018.10.14 模拟赛 砍树
数学问题... 根据题意,有: 移项,整理,得: 记 于是 那么 可以看到,最多只会有2*个取值(显而易见) 于是对应的,可能产生效果的d也只会有个,于是我们把他们找出来,扔进一个数组里然后排序,去重 ...