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;
}
}