Codeforces Round #491 (Div. 2)

Codeforces Round #491 (Div. 2)


A. If at first you don't succeed...

按题意判断

#include <bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;++i)
#define pb push_back
#define mem(W) memset(W,0,sizeof(W))
typedef long long ll;
inline int read() {char c=getchar();int x=0,f=1;while(!isdigit(c)){if(f=='-')f=-1;c=getchar();}while(isdigit(c)){x=x*10+c-'0';c=getchar();}return x*f;
}
using namespace std;
int n,a,b,c;
int main() {scanf("%d%d%d%d",&a,&b,&c,&n);int p = a+b-c;if(a>=c&&b>=c&&n-p>=1) printf("%d\n",n-p);else printf("-1\n");return 0;
}

B. Getting an A

排序之后,暴力修改加check...被fst。。。凉透

#include <bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;++i)
#define pb push_back
#define mem(W) memset(W,0,sizeof(W))
typedef long long ll;
inline int read() {char c=getchar();int x=0,f=1;while(!isdigit(c)){if(f=='-')f=-1;c=getchar();}while(isdigit(c)){x=x*10+c-'0';c=getchar();}return x*f;
}
using namespace std;
int n;
int a[111];
bool ck() {double x=0;rep(i,1,n)x+=a[i];x/=n;return (int)(x+0.5) == 5;
}
int main() {scanf("%d",&n);rep(i,1,n)scanf("%d",&a[i]);sort(a+1,a+n+1);int ans=0;rep(i,1,n+1) {if(ck()){printf("%d\n",ans);return 0;}if(a[i]<5){a[i]=5;++ans;}}return 0;
}

C. Candies

每次减\(\frac{1}{10}\)的这个操作使得数减小的非常快,二分k暴力模拟即可

#include <bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;++i)
#define pb push_back
#define mem(W) memset(W,0,sizeof(W))
typedef long long ll;
inline int read() {char c=getchar();int x=0,f=1;while(!isdigit(c)){if(f=='-')f=-1;c=getchar();}while(isdigit(c)){x=x*10+c-'0';c=getchar();}return x*f;
}
using namespace std;
ll n;
int ck(ll k) {ll tn=n,x,res=0;while(tn) {if(tn<k) res+=tn,tn=0;else tn-=k,res+=k;if(tn>=10){x = tn/10;tn -= x;}}return (res*2LL >= n);
}
int A[10000];
int main() {scanf("%I64d",&n);ll l=1,r=n,ans,mid;while(l<=r){mid = (l+r)/2LL;if(ck(mid))r=mid-1,ans=mid;else l=mid+1;}printf("%I64d\n",ans);return 0;
}

D. Bishwock

直接搜索即可。。。一开始推了个假的结论打算小范围暴力,然后dp,WA了。。。无奈交了暴力的代码。。过了

#include <bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;++i)
#define pb push_back
#define mem(W) memset(W,0,sizeof(W))
typedef long long ll;
inline int read() {char c=getchar();int x=0,f=1;while(!isdigit(c)){if(f=='-')f=-1;c=getchar();}while(isdigit(c)){x=x*10+c-'0';c=getchar();}return x*f;
}
using namespace std;
int n,ans;
char s[2][111];
void dfs(int now,int ed,int d){if(now==ed+1){ans = max(ans,d);return;}if(s[0][now-1]=='0'&&s[1][now-1]=='0'&&s[0][now]=='0'){s[0][now-1]=s[1][now-1]=s[0][now]='X';dfs(now+1,ed,d+1);s[0][now-1]=s[1][now-1]=s[0][now]='0';}else if(s[0][now-1]=='0'&&s[1][now-1]=='0'&&s[1][now]=='0'){s[0][now-1]=s[1][now-1]=s[1][now]='X';dfs(now+1,ed,d+1);s[0][now-1]=s[1][now-1]=s[1][now]='0';}else if(s[0][now-1]=='0'&&s[1][now]=='0'&&s[0][now]=='0'){s[0][now-1]=s[1][now]=s[0][now]='X';dfs(now+1,ed,d+1);s[0][now-1]=s[1][now]=s[0][now]='0';}else if(s[1][now-1]=='0'&&s[1][now]=='0'&&s[0][now]=='0'){s[1][now-1]=s[1][now]=s[0][now]='X';dfs(now+1,ed,d+1);s[1][now-1]=s[1][now]=s[0][now]='0';}else dfs(now+1,ed,d);
}
int solve(int l,int r){ans=0;dfs(l+1,r,0);return ans;
}
int dp[111];
int main() {scanf(" %s",s[0]);scanf(" %s",s[1]);n = strlen(s[0]);cout << solve(0,n-1) << endl;return 0;
}

E. Bus Number

统计0~9出现的次数,按题意暴力枚举每个数分别出现多少个,这个复杂度可以接受,对于每个情况设一共有sum个数字,A[i]为数字i出现的次数,那么\(\frac{sum!}{A[0]!A[1]!...A[9]!}\)为不管前导0情况下的排列数,现在考虑如何计算有前导0的情况,把非0的数仿照上边的方法求出排列数,现在把一个0放到开头,剩余的0插空放在这sum个数之间即可,这是经典的球盒模型,球无别,盒子有别可空。把上面两个值相减就是答案。。。。欲哭无泪的手速。。。

#include <bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;++i)
#define pb push_back
#define mem(W) memset(W,0,sizeof(W))
typedef long long ll;
inline int read() {char c=getchar();int x=0,f=1;while(!isdigit(c)){if(f=='-')f=-1;c=getchar();}while(isdigit(c)){x=x*10+c-'0';c=getchar();}return x*f;
}
const int N = 105;
using namespace std;
int n;
char s[33];
int p[N], notp[N], nxt[N], b[N];
void init(){notp[1]=1;nxt[1]=1;for(int i=2;i<=20;++i) {if(!notp[i]) p[++p[0]]=i,nxt[i]=i;for(int j=1;j<=p[0]&&i*p[j]<=20;++j) {notp[i*p[j]] = 1;nxt[i*p[j]]=p[j];if(i%p[j]==0)break;}}
}
ll q_pow(ll a,ll b) {ll ans=1;while(b) {if(b&1LL) ans=(ans*a);a=(a*a);b>>=1LL;}return ans;
}
inline void add(int x,int f) {while(x!=1){b[nxt[x]]+=f;x/=nxt[x];}
}
ll cal() {ll ans = 1;rep(i,1,p[0])ans = (ans*q_pow(p[i],b[p[i]])),b[p[i]]=0;return ans;
}
ll ans=0;
int sum=0,num[11],A[11];
string v;
set<string> ts;
void solve(){v.clear();rep(i,0,9)rep(j,1,num[i])v+=(char)('0'+i);int T = 1;for(int i=1;i<=v.size();++i) T*=i;while(T--){cout << v <<endl;if(v[0]!='0')ts.insert(v);next_permutation(v.begin(),v.end());}
}
void dfs(int t) {if(t==10){rep(i,1,sum)add(i,1);rep(i,0,9){rep(j,1,num[i]) add(j,-1);}//solve();ans += cal();if(num[0]){int m = sum-num[0]+1, n = num[0]-1;rep(i,1,m+n-1)add(i,1);rep(i,1,m-1)add(i,-1);rep(i,1,n)add(i,-1);rep(i,1,sum-num[0])add(i,1);rep(i,1,9)rep(j,1,num[i])add(j,-1);ans -= cal();}return;}if(A[t]==0)dfs(t+1);else {rep(i,1,A[t]){num[t]+=i;sum+=i;dfs(t+1);num[t]-=i;sum-=i;}}
}int main() {init();scanf(" %s",s);n=strlen(s);rep(i,0,n-1)++A[s[i]-'0'];dfs(0);printf("%I64d\n",ans);//cout << ts.size() << endl;return 0;
}

转载于:https://www.cnblogs.com/RRRR-wys/p/9219483.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320750.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习分享会(2019.5.31)

学习分享会 First&#xff08;初三大佬发言&#xff09; 初三大佬在为初二大佬讲一堆哲学的道理&#xff0c;虽然十分高深&#xff0c;但还是听懂了一点点 Second&#xff08;初二大佬发言&#xff09; 初二大佬开始“秀”&#xff0c;首先是大佬LW讲了讲十分常识的东西&am…

微软宣布公开预览Dev Spaces for AKS

微软宣布公开预览面向Azure Kubernetes Services&#xff08;AKS&#xff09;的Dev Spaces&#xff0c;为团队提供了一种快速的Kubernetes迭代开发体验。该版本是继5月份Build 2018大会上Dev Spaces内部预览之后的版本。借助这个版本&#xff0c;微软希望为开发人员提供一种在A…

YbtOJ#20068-[NOIP2020模拟赛B组Day5]连通子图【构造】

正题 题目链接:http://noip.ybtoj.com.cn/contest/102/problem/2 题目大意 求构造一个包含根节点的联通子图kkk个的树。 解题思路 现在考虑一棵树&#xff0c;如果我们在根节点处加一个点&#xff0c;那么方案数会2\times 22。如果在根节点上加入一个父节点&#xff08;根会…

2018 ACM-ICPC World Finals - Beijing

2018 ACM-ICPC World Finals - Beijing A. Catch the Plane \(dp[v_i,t_i]\)表示时刻\(t_i\)在\(v_i\)点&#xff0c;到达终点的最大概率&#xff0c;那么转移方程为&#xff1a;\(dp[(v_i,t_i)] max(P_{ij}*dp[(v_{j1},t_{j1})] (1-Pij)*dp[(v_{i1},t_{i1})])\)\(dp[(v_i,t_…

解析Visual C# 7.2中的private protected访问修饰符

去年12月份&#xff0c;随着Visual Studio 2017 Update 15.5的发布&#xff0c;Visual C#迎来了它的最新版本&#xff1a;7.2. 在这个版本中&#xff0c;有个让人难以理解的新特性&#xff0c;就是private protected访问修饰符&#xff08;Access Modifier&#xff09;。至此&a…

【Floyed】廉价最短路径

廉价最短路径 题目大意&#xff1a; 一个图中&#xff0c;在满足最短路的前提下&#xff0c;求最小代价 原题&#xff1a; 题目描述 图是由一组顶点和一组边组成的。一条边连接两个顶点。例如&#xff0c;图1表示了一个有4个顶点V、5条边的图。图中&#xff0c;每条边e是有…

CF401C-Team【构造】

正题 题目链接:https://www.luogu.com.cn/problem/CF401C 题目大意 构造一个序列包含nnn个000和mmm个111且不含有连续两个000和连续三个111。 解题思路 考虑用110110110和101010来构造序列即可。 codecodecode #include<cstdio> #include<cstring> #include<…

哈希学习笔记

hash学习笔记 常用函数: $ hash[i] \sum _{ji} ^{len-1} {s[j]*X^{j-i}}, X ≥ |字符集| $ 取多个模&#xff0c;对于一个子串\(s[i]s[i1]..s[j]\)的\(hash hash[i] - hash[j1]*X^{j-i1}\)&#xff0c;预处理\(hash[i]\)以及\(X^i\)即可\(O(1)\)求出所有的子串hash值一般运用…

Net Core集成Exceptionless分布式日志功能以及全局异常过滤

相信很多朋友都看过我的上篇关于Exceptionless的简单入门教程[asp.Net Core免费开源分布式异常日志收集框架Exceptionless安装配置以及简单使用图文教程][https://www.cnblogs.com/yilezhu/p/9193723.html] 上篇文章只是简单的介绍了Exceptionless是什么&#xff1f;能做什么呢…

【斐波那契】【前缀和】无限序列

无限序列 题目大意&#xff1a; 有这样一个规则&#xff1a;1.把“1”变成“10” 2.把“0”变成“1” 一个序列的第一位是“1” 然后是&#xff1a;“10”&#xff0c;“101”…… 序列无限次操作后会得到“1011010110110101101……” 问某一个区间内有多少个“1” 原题&…

CF496E-Distributing Parts【平衡树,贪心】

正题 题目链接:https://www.luogu.com.cn/problem/CF496E 题目大意 nnn个[li,ri][l_i,r_i][li​,ri​]&#xff0c;mmm个[ai,bi,ki][a_i,b_i,k_i][ai​,bi​,ki​]表示可以覆盖掉kik_iki​个ai≤li≤ri≤bia_i\leq l_i\leq r_i\leq b_iai​≤li​≤ri​≤bi​的区间&#xff0…

kmp学习笔记

kmp&#xff0c;扩展 kmp 学习笔记 说再前边 字符串水平基本为0&#xff0c;学了第4遍KMP了&#xff0c;总是忘。。。网上资料很多&#xff0c;就不详细讲解了。抄的kuangbin神犇模板 kmp 一些知识 循环节大小&#xff1a;n - nxt[n]模板[HDU2087] 下标从0开始 nxt[i] 为满足p[…

AspNetCore微服务下的网关-Kong(一)

Kong是Mashape开源的高性能高可用API网关和API服务管理层。它基于OpenResty&#xff0c;进行API管理&#xff0c;并提供了插件实现API的AOP。Kong在Mashape 管理了超过15,000 个API&#xff0c;为200,000开发者提供了每月数十亿的请求支持。本文将从架构、API管理、插件三个层面…

【DP】删数

删数 题目大意&#xff1a; 有一堆数x1,x2……xnx_1,x_2……x_nx1​,x2​……xn​&#xff0c;可以从两边删除一些数删除i~k的价值是∣xi–xk∣∗(k−i1)|xi – xk|*(k-i1)∣xi–xk∣∗(k−i1)&#xff0c;求价值最大是多少 原题&#xff1a; 题目描述 有N个不同的正整数数…

CF396B-On Sum of Fractions【数学】

正题 题目链接:https://www.luogu.com.cn/problem/CF396B 题目大意 定义 v(n)v(n)v(n)表示≤n\leq n≤n的最大整数u(n)u(n)u(n)表示>n>n>n的最小整数 求∑i2n1v(i)u(i)\sum_{i2}^n\frac{1}{v(i)u(i)}i2∑n​v(i)u(i)1​ 解题思路 有式子b−aab1a−1b\frac{b-a}{ab…

拥抱开源, Office 365开发迎来新时代

这个话题我曾经写过文章&#xff0c;也在一些场合做过专题分享。今天换一种方式&#xff0c;你可以直接点击下面这个小程序&#xff0c;用十分钟左右的时间&#xff0c;听我再讲一讲吧。你需要在微信里面才能看到下面的小程序链接&#xff0c;并且可以直接点击你可以打开该文档…

Wannafly挑战赛19

Wannafly挑战赛19 A. 队列Q 需要支持把一个元素移到队首&#xff0c;把一个元素移到队尾&#xff0c;移到队首就直接放到队首前面那个位置&#xff0c;原位置标为0&#xff0c;队尾同理。 #include <bits/stdc.h> #define rep(i,a,b) for(int ia;i<b;i) typedef long …

【模拟】俄罗斯方块

俄罗斯方块 题目大意&#xff1a; 在俄罗斯方块中&#xff0c;放一块方块进一个图中&#xff0c;问刚好和上的可能性有多少种 原题&#xff1a; 题目描述 相信大家都玩过“俄罗斯方块”游戏吧&#xff0c;“俄罗斯方块”是一个有趣的电脑小游戏&#xff0c;现有一个有C列、…

实体类的动态生成(一)

前言在应用开发中&#xff0c;通常都会涉及各种 POJO/POCO 实体类&#xff08;DO, DTO, BO, VO&#xff09;的编写&#xff0c;有时这些实体类还需要实现 INotifyPropertyChanged 接口以支持属性变更通知&#xff0c;一般我们都会手写这些代码或者通过工具根据数据库表定义抑或…

CF525D-Arthur and Walls【贪心】

正题 题目链接:https://www.luogu.com.cn/problem/CF525D 题目大意 n∗mn*mn∗m的网格&#xff0c;有∗*∗和...&#xff0c;每次可以将∗*∗改成...。求最少操作使得每个...所在的联通块都是一个矩形。 解题思路 因为一个大矩形中每一个小块也是一个矩形&#xff0c;反之同理…