A. Deadline

题目链接

题目大意

给你\(n,d\)两个数,问是否存在\(x\)使得\(x+\frac{d}{x+1}\leq n\),其中\(\frac{d}{x+1}\)向上取整。

解题思路

  • 方案一:利用均值不等式公式推导

    \(x+\frac{d}{x+1}=x+1+\frac{d}{x+1}-1\geq2\sqrt{d}-1\)

    所以 \(\min(x+\frac{x}{d+1})=2\sqrt{d}-1\)

    因此去判断\(2\sqrt{d}-1\leq n\)是否成,即\(4\times n^2\leq (n+1)^2\)是否成立即可。

  • 方案二:暴力判断

    很明显的一点就是\(x\)的值不会超过\(\sqrt{d}\),所以遍历判断一下即可。

AC代码1

#include<bits/stdc++.h>
using namespace std;
int main()
{
int t;
cin>>t;
while(t--){
long long n,d;
cin>>n>>d;
if(4*d<=(n+1)*(n+1)){
cout<<"YES"<<endl;
}else{
cout<<"NO"<<endl;
}
}
return 0;
}

AC代码2

#include<bits/stdc++.h>
const int maxn=1e3+100;
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
int main()
{
// freopen("data.txt","r",stdin);
int t;
cin>>t;
while(t--){
int n,d;
cin>>n>>d;
bool flag=false;
for(int i=0;i*i<=d;i++){
if((i+d/(i+1)+(d%(i+1)==0?0:1))<=n){
flag=true;
}
}
if(flag)cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}
return 0;
}

总结

最开始拿到这道题的时候居然有点懵,其实应该理所应当的想到\(x\)的值不会超过\(\sqrt{d}\)

B. Yet Another Meme Problem

题目链接

题目大意

给你两个数\(A,B\),求满足\(1\leq a \leq A\),\(1\leq b \leq B\)并且 \(a\times b+ a+b = a\times 10^{b的位数}+b\)的个数。

解题思路

在做这道题的时候其实出题人已经给了提示,所以很轻松的想到了结论,即找到满足\(\leq b\)并且每一位都是\(9\)的数字个数\(\times a\)即为答案。

结论推导:

\(a\times b+a+b=a\times 10^{b的位数}+b\)

\(a\times b+a = a\times 10^{b的位数}\)

\(a\times (b+1) = a\times 10^{b的位数}\)

\(b+1 = 10^{b的位数}\)

所以只有所有位都是\(9\)的数字才能满足,即\(9,99,999,\cdots\)

AC代码

#include<bits/stdc++.h>
const int maxn=1e3+100;
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
int main()
{
// freopen("data.txt","r",stdin);
int t;
cin>>t;
while(t--){
ll a,b;
cin>>a>>b;
string str = to_string(b);
int len = str.size()-1;
bool flag = true;
for(int i=0;i<str.size();i++){
if(str[i]!='9'){
flag=false;
break;
}
}
if(flag)len++;
cout<<a*len<<endl;
}
return 0;
}

总结

这道题自己在求数字个数的时候用的是字符串求法,其实如果不是大数的话,个人认为用整数运算即可,还方便点。丢个代码出来。

int cnt=0;
int number=9;
while(number<=b){
number = number*10+9;
cnt++;
}

C. Two Arrays

题目链接

题目大意

给你两个数字\(n,m\),求用\(1\cdots n\)这\(n\)个数(数字可以重复)构造出两个长度为\(m\)的数组\(a,b\)满足一下要求的数组数量。

  • 对于数组\(a,b\)中所有元素都满足\(a_i\leq b_i\)
  • 数组\(a\)是非递减的
  • 数组\(b\)是非递增的

解题思路

啊啊啊,这道题自己在做的时候没有想到把两个数组给合起来,思维太线性了,没有转过弯。数组\(a\)是非递减的,数组\(b\)是非递增的,如果将数组\(b\)反转连接在数组\(a\)的后面就是一个非递减数组,那么题目要求就转化为求用\(1\cdots n\)这\(n\)个数构造一个长度为\(2\times m\)的非递减数组的个数。

  • 复杂度为\(O(n^2m)\)的转移方程

    \(dp[i][j]\)表示第\(i\)个位置放数字\(j\)的方案数,那么\(dp[i][j]=\sum_{k=1} ^j dp[i-1][k]\)

  • 复杂度为\(O(nm)的转移方程\)

    \(dp[i][j]\)表示第\(i\)个位置放数字\(j\)的方案数,那么\(dp[i][j]=dp[i-1][j]+dp[i][j-1]\),这里利用了前缀和的思想。

    推导如下:

    \(dp[i][j]=\sum_{k=1} ^j dp[i-1][k]=\sum_{k=1}^{j-1}dp[i-1][k]+dp[i-1][j]\)

    因为\(dp[i][j-1]=\sum_{k=1} ^{j-1} dp[i-1][k]\)

    所以 \(dp[i][j]=dp[i-1][j]+dp[i][j-1]\)

    又或者在不知道如何推导的情况下可以从思维上这样想

    在第\(i\)个位置上可以放\(j-1\),那么在第\(i\)个位置上肯定也可以放\(j\),所以放\(j\)的个数肯定会包含放\(j-1\)的个数,但这样得到的所有方案在\(i-1\)这个位置上最大的是\(j-1\),其实在\(i-1\)这个位置可以放\(j\),所以再加上第\(i-1\)位置上放\(j\)的方案数。

AC代码

#include<bits/stdc++.h>
const int mod=1e9+7;
const int maxn=2e1+10;
const int maxm=1e3+20;
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
int dp[maxn][maxm];
int main()
{
// freopen("data.txt","r",stdin);
int n,m;
cin>>n>>m;
for(int i=1;i<=n;i++)dp[1][i]=1; for(int i=2;i<=2*m;i++){
for(int j=1;j<=n;j++){
dp[i][j]=(dp[i][j-1]+dp[i-1][j])%mod;
}
}
ll ans=0;
for(int i=1;i<=n;i++){
ans+=dp[2*m][i];
ans%=mod;
}
cout<<ans<<endl;
return 0;
}

总结

后悔拿到这道题没思考,再仔细思考一下,在理解题目的意思之后应当建立对应的模型,思维不能太线性了。

Educational Codeforces Round 80 (Rated for Div. 2)部分题解的更多相关文章

  1. Educational Codeforces Round 48 (Rated for Div. 2) CD题解

    Educational Codeforces Round 48 (Rated for Div. 2) C. Vasya And The Mushrooms 题目链接:https://codeforce ...

  2. Educational Codeforces Round 59 (Rated for Div. 2) DE题解

    Educational Codeforces Round 59 (Rated for Div. 2) D. Compression 题目链接:https://codeforces.com/contes ...

  3. Educational Codeforces Round 80 (Rated for Div. 2)

    A. Deadline 题目链接:https://codeforces.com/contest/1288/problem/A 题意: 给你一个 N 和 D,问是否存在一个 X , 使得 $x+\lce ...

  4. Educational Codeforces Round 80 (Rated for Div. 2)D E

    D枚举子集 题:https://codeforces.com/contest/1288/problem/D题意:给定n个序列,每个序列m个数,求第i个和第j个序列组成b序列,b序列=max(a[i][ ...

  5. Educational Codeforces Round 80 (Rated for Div. 2) E. Messenger Simulator

    可以推出 min[i]要么是i要么是1,当a序列中存在这个数是1 max[i]的话就比较麻烦了 首先对于i来说,如果还没有被提到第一位的话,他的max可由他后面的这部分序列中 j>=i 的不同数 ...

  6. Educational Codeforces Round 80 (Rated for Div. 2)(A-E)

    C D E 这三道题感觉挺好       决定程序是否能通过优化在要求的时间内完成,程序运行时间为t,你可以选择花X天来优化,优化后程序的运行时间为t/(x+1)取上整,花费的时间为程序运行时间加上优 ...

  7. Educational Codeforces Round 80 (Rated for Div. 2)E(树状数组,模拟,思维)

    #define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; ],mx[],a[],pos[],sum ...

  8. Educational Codeforces Round 80 (Rated for Div. 2)D(二分答案,状压检验)

    这题1<<M为255,可以logN二分答案后,N*M扫一遍表把N行数据转化为一个小于等于255的数字,再255^2检验答案(比扫一遍表复杂度低),复杂度约为N*M*logN #define ...

  9. Educational Codeforces Round 80 (Rated for Div. 2)C(DP)

    #define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; ; ][],temp[][]; int ...

随机推荐

  1. 开发板免费领!腾讯云IoT应用创新大赛正式启动!

    大赛简介 腾讯云IoT应用创新大赛是腾讯云面向物联网领域举办的大型竞赛,通过腾讯云IoT全链路产品能力,开放平台和服务,与广大开发者共同创新,孵化优秀的IoT产品和解决方案,共同构建IoT应用生态. ...

  2. java中如何自动获取电脑的ip地址

    String ip=InetAddress.getLocalHost().getHostAddress().toString(); 可以写一个main方法测试一下.

  3. Excel解除'工作表保护密码',并复原密码设定

    前提要求 Office 2003(也就是老版的.xls文件) 用到宏操作 可以解除[审阅->保护工作表]的密码保护,其他的密码保护不能处理. 解决方案 打开需解除保护密码的Excel文件(.xl ...

  4. 第一次看CCControl

    Control中有九种可能的事件,定义在.h文件中,另外还定义四种状态,用来表示控件高亮等. 在初始化控件的时候: bool Control::init() { if (Layer::init()) ...

  5. Qt Quick QMl学习笔记 之图片浏览器

    Qt Quick模块是编写QML应用程序的标准库.虽然Qt QML模块提供QML引擎和语言基础结构,但Qt Quick模块提供了使用QML创建用户界面所需的所有基本类型.它提供了一个可视画布,包括用于 ...

  6. ObjectArx 使用消息钩子实现鼠标滚轮旋转实体

    测试结果: 实现方法:主要是程序注册一个消息函数:func,拦截鼠标滚轮触发的消息,需要注意的是,以写的方式处理实体时需要锁定文档.注册func的主要方法是:BOOL acedRegisterFilt ...

  7. 02_css3.0 前端长度单位 px em rem vm vh vm pc pt in 你真的懂了吗?

    1:废话不多说,直接看如下图表: 2:px就不过多介绍了,就是像素点的大小,加入您的屏幕分辨率为1920,则每一个相当于每一个有横着的1920个像素点: 3:em 为相对单位,一般以 body 内的 ...

  8. 在.NET Core中批量注入Grpc服务

    GRPC 是谷歌发布的一个开源.高性能.通用RPC服务,尽管大部分 RPC 框架都使用 TCP 协议,但其实 UDP 也可以,而 gRPC 干脆就用了 HTTP2.还有就是它具有跨平台.跨语言 等特性 ...

  9. Linux学习_菜鸟教程_1

    Linux系统启动过程:内核的引导 .运行init.系统初始化.建立终端.用户登录系统 内核引导:计算机开机,然后BIOS开机自检,按照BIOS中设置的启动设备(通常是硬盘)来启动. 操作系统接管硬件 ...

  10. 杂谈.netcore的Buffer相关新类型

    1 文章范围 本文将.netcore新出现的与Buffer操作相关的类型进行简单分析与讲解,由于资料有限,一些见解为个人见解,可能不是很准确.这些新类型将包括BinaryPrimitives.Span ...