返回 课程

信奥AC之路-3级

0% 完成
0/0 步骤
  1. 第一课:数组基础
    4 主题|小节
  2. 第二课:数组基础二
    6 主题|小节
  3. 第三课:数组基础三
    6 主题|小节
  4. 第四课:数组基础四
    7 主题|小节
  5. 第五课:数组基础五
    5 主题|小节
  6. 第六课:数组用于统计,去重,排序
    5 主题|小节
  7. 第七课:冒泡排序
    6 主题|小节
  8. 第八课:数组连续性元素
    6 主题|小节
  9. 第九课:数组综合一
    7 主题|小节
  10. 第十课:字符数组
    7 主题|小节
  11. 第十一课:字符数组基础应用
    5 主题|小节
  12. 第十二课:字符数组基础应用二
    6 主题|小节
  13. 第十三课:字符数组进阶
    6 主题|小节
  14. 第十四课:字符串进阶二
    6 主题|小节
  15. 第十五课:字符串(STL)
    9 主题|小节
  16. 第十六课:字符串基础
    6 主题|小节
  17. 第十七课:字符串函数
    6 主题|小节
  18. 第十八课:字符串函数二
    4 主题|小节
  19. 第十九课:sort函数
    7 主题|小节
  20. 第二十课:字符串进阶
    7 主题|小节
  21. 第二十一课:字符串进阶二
    6 主题|小节
  22. 第二十二课:进制转换--十进制转其他进制
    5 主题|小节
  23. 第二十三课:进制转换--其他进制转十进制
    5 主题|小节
  24. 第二十四课:二进制,八进制,十六进制转换
    5 主题|小节
  25. 第二十五课:数据编码基础
    6 主题|小节
  26. 第二十六课:位运算基础
    6 主题|小节
课 13, 主题|小节 5
进行中

13.5 隐藏数字的发现

2025年9月22日
课 进展
0% 完成

“小朋友们,有时候数字会藏在一串字符中,”我神秘地说,”今天我们要学习如何从混合字符串中找出最大的隐藏整数!”

13.5.1 寻找隐藏的最大整数

题目描述: 整数小伙伴们在玩捉迷藏,它们藏在一个长长的字符串中。我们需要找到隐藏在字符串中最大的那个整数的位置。隐藏的整数不会以0开头,且可能超过20位。

输入格式: 只有一个字符串,里面藏有很多的整数(字符串长度≤100,且不含空格)。

输出格式: 只有一个整数,表示藏在其中的最大的那个整数小伙伴的位置(整数第一个数字在原串中的位置)。

样例输入

*((*-a32AB342+//32143abAA

样例输出

17

代码实现

#include<bits/stdc++.h>
using namespace std;

int main(){
    char a[110];           // 存储输入的字符串
    char b[110] = {''};  // 存储当前正在处理的数字
    char c[110] = {''};  // 存储目前找到的最大数字
    
    cin >> a;              // 输入字符串
    int k = 0;             // b数组的当前位置
    int d;                 // 存储最大数字的结束位置
    
    // 遍历整个字符串
    for(int i = 0; i < strlen(a); i++){
        if(isdigit(a[i])){  // 如果是数字字符
            b[k++] = a[i];  // 添加到当前数字中
            
            // 如果到达字符串末尾或下一个字符不是数字,说明数字结束
            if(i == strlen(a) - 1 || !isdigit(a[i + 1])){
                b[k] = '';  // 添加字符串结束符
                
                // 去除前导零
                int l = 0;
                while(b[l] == '0' && strlen(b) > 1 && l < strlen(b) - 1){
                    l++;  // 跳过前导零
                }
                
                // 将去除前导零后的数字移到数组开头
                for(int x = 0, j = l; j < strlen(b); j++, x++){
                    b[x] = b[j];
                    if(j == strlen(b) - 1) b[++x] = '';
                }
                
                // 比较当前数字与已找到的最大数字
                if(strlen(b) > strlen(c)){
                    // 如果当前数字位数更多,直接更新
                    strcpy(c, b);
                    d = i;  // 记录结束位置
                }
                else if(strlen(b) == strlen(c) && strcmp(b, c) > 0){
                    // 如果位数相同但字典序更大,更新
                    strcpy(c, b);
                    d = i;  // 记录结束位置
                }
                k = 0;  // 重置当前数字位置
            }
        }
    }
    
    // 计算最大数字的起始位置
    cout << d + 1 - strlen(c) + 1;
    return 0;
}

算法解析

  1. 逐字符遍历字符串,提取所有数字串
  2. 对每个数字串去除前导零
  3. 比较数字大小:
    • 首先比较位数,位数多的更大
    • 位数相同时,使用字典序比较
  4. 记录最大数字的结束位置,通过长度计算起始位置
  5. 最终输出最大数字在原字符串中的起始位置