题目:给定任意一个正整数,求比这个数大且最小的“不重复数”,“不重复数”的含义是相邻两位不相同,例如1101是重复数,而1201是不重复数。
算法:
1、把整数放到字符数组里面去,从高位为低位(用变量i)扫描,找到重复的数位,重复数位为“99”跳到第2步,否则跳到第3步,若
没有重复的数位,则该数为不重复数,返回;
2、遇到“99”的重复数,则把“99”改为“00”,然后在“99”前面一位字符加1,把扫描的地方定位在“99”往高位方向的第2位,比如是
1299,变换后为1300,然后把扫描变量 i 定位在1这一数位上,返回第1步;
3、遇到非“99”的重复数,则直接在低位加1,后面依次变为010101……,结果就是最小的不重复数,返回改值;
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define SIZE 100
int getNumNonrepetition(const long long NumGived, char NumStr[])
{
int NumTmp = NumGived;
int NumLength = 0;
int i = SIZE - 1;
//把整数放到字符数组里面去,从后往前放,比如1234,
//那么数组NumStr[96] = 1 NumStr[97] = 2 NumStr[98] = 3 NumStr[99] = 4, SIZE = 100
do
{
NumStr[i] = NumTmp % 10 + '0';
NumTmp /= 10;
i--;
}
while(NumTmp != 0);
NumLength = SIZE - i - 1;//计算整数的位数
int flag = 0;//设置010101的时候用的变量
i = SIZE - NumLength;
while( 1 )
{
//定位到重复的位上面,下标i + 1为低位,此时NumStr[i] == NumStr[i + 1]
while(i + 1 < SIZE && NumStr[i] != NumStr[i + 1]) i++;
if(i == SIZE - 1) break;//扫完一遍,没有重复的,跳出循环,该数是不重复数
if(NumStr[i + 1] == '9')//重复的数位为99这种情况,将这两位全部置0,高位加1
{
NumStr[i + 1] = '0';
i--;
NumStr[i + 1] = '0';
i--;
NumStr[i + 1] += 1;
}
else//重复的
{
//低位加1
NumStr[i + 1] += 1;
i += 2;
flag = 0;
//后续全部设为0101……,这个时候肯定是不重复数了,所以可以跳出循环
while( i < SIZE )
{
NumStr[i] = flag % 2+ '0';
flag++;
i++;
}
break;
}
}
//打印最小的”不重复数“
int start = SIZE - NumLength;
//如果是99开头的数字,高位可能会进位,判断是否为零,不为零则有进位,需打印出来
if(NumStr[start - 1] != '0') putchar(NumStr[start - 1]);
for(i = start; i < SIZE; i++ )
{
putchar(NumStr[i]);
}
return 0;
}
int main(void)
{
long long NumGived = 119998988;
char NumStr[SIZE];
memset(NumStr, '0', SIZE * sizeof(char));
getNumNonrepetition(NumGived, NumStr);
return 0;
}