CF1467A
显然:
- nnn 为 111 时答案为 999
- nnn 为 222 时答案为 989898
- nnn 为 333 时答案为 989989989
当 n>3n>3n>3 时,假设我们在第 xxx 秒选择让第 iii 个位置暂停,如果 i>2i>2i>2 或 i=1i=1i=1,那么最终得到的答案的前三位一定比 989989989 要小。因此当 n>3n>3n>3 时最优方案就是 n=3n=3n=3 时的方案:在第 888 秒时暂停第 222 个位置。
代码如下:
/*
_/ _/ _/_/_/ _/_/_/ _/_/_/_/_/ _/_/_/ _/_/_/_/ _/ _/ _/ _/ _/ _/
_/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/
_/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/
_/ _/ _/_/_/_/_/ _/ _/ _/ _/ _/_/_/_/ _/ _/ _/ _/ _/_/
_/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/
_/_/ _/ _/ _/ _/ _/ _/ _/ _/ _/ _/_/_/_/ _/ _/ _/
_/ _/_/_/ _/_/_/ _/ _/_/_/ _/ _/ _/ _/ _/ _/ _/
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define ll long long
#define fo(i,x,y) for(register int i=x;i<=y;++i)
#define go(i,x,y) for(register int i=x;i>=y;--i)
using namespace std;
inline int read(){
int x=0,fh=1;
char ch=getchar();
while(!isdigit(ch)){
if(ch=='-') fh=-1;
ch=getchar();
}
while(isdigit(ch)){
x=(x<<1)+(x<<3)+ch-'0';
ch=getchar();
}
return x*fh;
}
string s="989";
void work(){
int n=read();
if(n<=3){
cout<<s.substr(0,n)<<endl;
return;
}
cout<<s;
fo(i,0,n-4) printf("%d",i%10);
puts("");
}
int main(){
int T=read();
while(T--){
work();
}
return 0;
}
CF1467B
考虑将某个位置变成哪些值是可能产生贡献的。由于 aia_{i}ai 的变化为影响三个位置:ai−1,ai,ai+1a_{i-1},a_{i},a_{i+1}ai−1,ai,ai+1
博客对CF1467A和CF1467B进行了解题分析。对于CF1467A,给出了n为不同值时的答案,分析了n>3时的最优方案并给出代码;对于CF1467B,考虑了将某个位置变成哪些值可能产生贡献,因ai变化会影响三个位置。
1331

被折叠的 条评论
为什么被折叠?



