C. Long Beautiful Integer------思维(稍难)

You are given an integer x of n digits a1,a2,…,an, which make up its decimal notation in order from left to right.

Also, you are given a positive integer k<n.

Let’s call integer b1,b2,…,bm beautiful if bi=bi+k for each i, such that 1≤i≤m−k.

You need to find the smallest beautiful integer y, such that y≥x.

Input
The first line of input contains two integers n,k (2≤n≤200000,1≤k<n): the number of digits in x and k.

The next line of input contains n digits a1,a2,…,an (a1≠0, 0≤ai≤9): digits of x.

Output
In the first line print one integer m: the number of digits in y.

In the next line print m digits b1,b2,…,bm (b1≠0, 0≤bi≤9): digits of y.

Examples
inputCopy

3 2
353
outputCopy
3
353
inputCopy
4 2
1234
outputCopy
4
1313

题意:给定一个a序列,长度为n,值为x,让你构造一个b序列满足b[i]=b[i+k],这个值为y,y>=x,且y最小。

解析:对于n位数 99…999一定是最优的,所以求出y的长度肯定还是n!
我们可以给第k-1位+1,这样就可以构成最优解最小的且>=x.但在这个之前我们还会有两种情况出现。
第一种就是本身就是最优解。
第二种就是我们重复前k位,得到的y 是否>=x 如大于就是我们需要的答案。
第三种就是一开始讲的,但还要再细分两种。
1)第k-1位是9,这时候+1我们要产生进位的。需要处理一下
2)第k-1位不是9,我们就重复前k位。

#include<bits/stdc++.h>
using namespace std;
const int N=1e6+10000;
string s;
int a[N],b[N],c[N],n,k;
int main()
{
	cin>>n>>k;
	cin>>s;
	for(int i=0;i<n;i++) a[i]=s[i]-'0';
	int f=1;
	for(int i=0;i<n-k;i++) //检查本身是否存在正确性 
	{
		if(a[i]!=a[i+k])
		{
			f=0;
			break;
		}
	}
	if(f==1)
	{
		cout<<n<<endl;
		cout<<s<<endl;
		return 0;
	}
	for(int i=0;i<n;i++) b[i]=a[i];      //重复前k位,是否能构成>=x 
	for(int i=k;i<n;i++) b[i]=b[i-k];
	 f=1;
	for(int  i=0;i<n;i++)
	{
		if(a[i]==b[i]) continue; //相等跳过 
		if(a[i]>b[i] ) f=0; //得到比原来的更小了不行 
		if(a[i]<b[i]) break;//得到比原来的大,就可以了。因为后继一定满足 
	}
	if(f==1)
	{
		cout<<n<<endl;
		for(int i=0;i<n;i++) cout<<b[i];
		cout<<endl;
		return 0;
	 } 
	 for(int i=k-1;i>=0;i--) //从第k-1位+1,这样会构成最优解就是最小值的,如果是9肯定产生进位,我们先跳过,等遇到不是9的情况,再给后面赋值0 
	 {
	 	if(a[i]==9) continue;
	 	a[i]=a[i]+1;
	 	for(int j=i+1;j<=k-1;j++) a[j]=0;
	 	for(int j=k;j<n;j++) a[j]=a[j-k];
	 	cout<<n<<endl;
	 	for(int j=0;j<n;j++) cout<<a[j];
	 	cout<<endl;
	 	return 0;
	 }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值