现在有一个20位以内的自然数,你可以将组成这个数的各位数字重新排列,得到一个数值为最小的新数,但新数的位数保持不变。请编程打印出重新排列后的新数。(如:231重新排序后位数不变的最小数是123,而23105重新排序后位数不变的最小数是10235。)
输入格式
一个整数(位数 <= 20)
输出格式
重新排列后最小的新数
样例输入
382
样例输出
238
关于#c++#的问题:)输入格式一个整数(位数 <= 20)输出格式重新排列后最小的新数样例输入382样例输出238
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 旺仔不爱牛奶 2021-08-21 20:01关注
#include <iostream> #include <string> using namespace std; // 统计字符串中各种数字出现的次数 void statistics(string number, int* frequency) { for (int i = 0; i < 10; ++i) frequency[i] = 0; for (int i = 0; i < number.length(); ++i) { ++frequency[(int)(number[i] - '0')]; } } int main() { string number; string min; cin >> number; int frequency[10]; statistics(number, frequency); for(int i=1;i<10;++i) if (frequency[i] != 0) { min += ('0' + i); --frequency[i]; break; } for (int i = 0; i < 10; ++i) { while (frequency[i] != 0) { min += ('0' + i); --frequency[i]; } } cout << min; return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥50 vue组件中无法正确接收并处理axios请求
- ¥15 隐藏系统界面pdf的打印、下载按钮
- ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
- ¥15 基于pso参数优化的LightGBM分类模型
- ¥15 安装Paddleocr时报错无法解决
- ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
- ¥50 分布式追踪trace异常问题
- ¥15 人在外地出差,速帮一点点
- ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改
- ¥50 vue router 动态路由问题