CF1467(Round 695 div2)题解

CF1467A

显然:

  • n n n 1 1 1 时答案为 9 9 9
  • n n n 2 2 2 时答案为 98 98 98
  • n n n 3 3 3 时答案为 989 989 989

n > 3 n>3 n>3 时,假设我们在第 x x x 秒选择让第 i i i 个位置暂停,如果 i > 2 i>2 i>2 i = 1 i=1 i=1,那么最终得到的答案的前三位一定比 989 989 989 要小。因此当 n > 3 n>3 n>3 时最优方案就是 n = 3 n=3 n=3 时的方案:在第 8 8 8 秒时暂停第 2 2 2 个位置。

代码如下:

/*
 
_/      _/    _/_/_/      _/_/_/    _/_/_/_/_/    _/_/_/    _/_/_/_/    _/      _/  _/      _/  _/      _/
_/      _/  _/      _/  _/      _/      _/      _/      _/  _/      _/  _/      _/   _/    _/    _/    _/
_/      _/  _/      _/  _/              _/      _/      _/  _/      _/  _/      _/    _/  _/      _/  _/
_/      _/  _/_/_/_/_/  _/              _/      _/      _/  _/_/_/_/    _/  _/  _/      _/         _/_/
  _/  _/    _/          _/              _/      _/      _/  _/  _/      _/  _/  _/      _/        _/  _/
   _/_/     _/      _/  _/      _/      _/      _/      _/  _/    _/     _/_/_/_/       _/       _/    _/
    _/        _/_/_/      _/_/_/        _/        _/_/_/    _/      _/    _/  _/        _/      _/      _/
 
*/
#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

考虑将某个位置变成哪些值是可能产生贡献的。由于 a i a_{i} ai 的变化为影响三个位置: a i − 1 , a i , a i + 1 a_{i-1},a_{i},a_{i+1} ai1,ai,ai+1

posted @ 2021-01-09 01:19  真正的菜鸡vectorwyx  阅读(46)  评论(0)    收藏  举报