给定一个N位的数,返回由这N个数组成的比原来的数大数中的最小的数
2010-11-25 22:33
232 查看
/*
* 给定一个N位的数,返回由这N个数组成的比原来的数大数中的最小的数
*/
#include<cstdio>
#include<string>
#include<stdlib.h>
int cmp(const void*a, const void*b)
{
return *(char*)a - *(char*)b;
}
int main()
{
char str[1024];
int len;
int i, j;
char temp;
int done = 0;
char* ctmp = new char[1024];
ctmp[0] = '/0';
scanf("%s", str);
while(str!="#")
{
len = strlen(str);
for(i=len-1; i>0; i--)
{
for(j=i-1; j>-1; j--)
{
if(str[j]<str[i])
{
temp = str[j];
str[j] = str[i];
str[i] = temp;
done = 1;
break;
}
}
if(done) break;
}
if(i==0)
printf("No Successor/n");
else
{
strcpy(ctmp, &str[j+1]);
str[j+1]='/0';
qsort(ctmp, strlen(ctmp), sizeof(char), cmp);
strcat(str, ctmp);
printf("%s/n", str);
}
scanf("%s", str);
}
return 0;
}
* 给定一个N位的数,返回由这N个数组成的比原来的数大数中的最小的数
*/
#include<cstdio>
#include<string>
#include<stdlib.h>
int cmp(const void*a, const void*b)
{
return *(char*)a - *(char*)b;
}
int main()
{
char str[1024];
int len;
int i, j;
char temp;
int done = 0;
char* ctmp = new char[1024];
ctmp[0] = '/0';
scanf("%s", str);
while(str!="#")
{
len = strlen(str);
for(i=len-1; i>0; i--)
{
for(j=i-1; j>-1; j--)
{
if(str[j]<str[i])
{
temp = str[j];
str[j] = str[i];
str[i] = temp;
done = 1;
break;
}
}
if(done) break;
}
if(i==0)
printf("No Successor/n");
else
{
strcpy(ctmp, &str[j+1]);
str[j+1]='/0';
qsort(ctmp, strlen(ctmp), sizeof(char), cmp);
strcat(str, ctmp);
printf("%s/n", str);
}
scanf("%s", str);
}
return 0;
}
相关文章推荐
- 给定一个N位的数,返回由这N个数组成的比原来的数大数中的最小的数
- 给定一个整数,求比该整数大的最小的整数,其数字能够组成一个回文
- 给定一个字符串列表,找出单词中最长单词,可以用l列表中的其他单词一次构建一个字符。返回具有最小字典顺序的最长单词。
- 2018阿里校招笔试——给定一个字符串S和有效单词的字典D,请确定可以插入到S中的最小空格数,使得最终的字符串完全由D中的有效单词组成,并输出解。
- 谷歌笔试题--给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数。
- 谷歌笔试题--给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数。
- 谷歌笔试题--给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数。
- 一个n位的数,去掉其中的k位,问怎样去使得留下来的(n-k)位数按原来的前后顺序组成的数最小
- 给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数。
- 给定一个数组,元素都是正整数,要求返回这些元素所组成的最大数
- 华为机试题----比较二维数组列最小值,组成一个新数组返回
- 一个n位的数,去掉其中的k位,问怎样去使得留下来的(n-k)位数按原来的前后顺序组成的数最小
- 定义一个由整数组成的数组,然后输入一个整数X,如果X不在此数组中,返回小于X的最大数的位置i和大于X的最小数的位置j
- 给定一个集合A=[0,1,3,8](该集合中的元素都是在0,9之间的数字,但未必全部包含), 指定任意一个正整数K,请用A中的元素组成一个大于K的最小正整数。
- 阿里校招笔试——给定一个字符串S和有效单词的字典D,请确定可以插入到S中的最小空格数,使得最终的字符串完全由D中的有效单词组成,并输出解。
- 给定一个字符串s由大小写字母和空白字符组成,返回字符串中最后一个字的长度。 如果最后一个字不存在,则返回0。
- 写出一个算法,对给定的n个数的序列,返回序列中的最大和最小的数
- 一个n位的数,去掉其中的k位,问怎样去使得留下来的(n-k)位数按原来的前后顺序组成的数最小
- 123 请用 A 中的元素组成一个大于 K 的最小正整数
- 整型数组处理算法(九)给定任意一个正整数,求比这个数大且最小的“不重复数”(性能优化)[2014百度笔试题]