原题链接:最大数字
解题思路:
当输入n = 143329,
k = 1 ---> 432219
k = 2 ---> 43229
k = 3 ---> 4329
这里我们假设有两个映射函数f(n, k), g(n)
f(n , k) 函数是用来求整数n删除k个数后的最大数,即题目要求。
g(n) 函数是用来求整数n删除1个数后的最大数
那么可以有如下表达式
f(n, 3) = g(f(n, 2)); // k = 3 是由k = 2得来的
f(n, 2) = g(f(n, 1));
f(n, 1) = g(f(n , 0));
特殊情况f(n, 0) = n;
注意事项:
参考代码:
#include <stdio.h> int main() { char str[102]; // 输入数最大为101位 int len; int k; scanf("%s %d", str, &k); len = strlen(str); int i; while (k--) { // 删除k个数 for (i = 0; i < len - 1 && str[i] >= str[i + 1]; i++); // 找到比下一个字符小的位置 for (i++; i < len && (str[i - 1] = str[i]); i++); // i后面的字符前移1位 len--; // 删除字符,长度减1 } str[len] = '\0'; // 在len处放入'\0',字符串终止标识符 printf("%s", str); return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复