解题思路:


当输入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分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论