GESP 24年12月2级 数位和

【题目链接】

一本通 4092 数位和
洛谷 B4065 数位和


【题目考点】

  1. 循环结构 (嵌套);

  2. 数位拆分;

  3. 擂台法(求最值);


【解题逻辑】

  1. 输入整数n,循环指定的n次;

  2. 定义变量 maxsum 并初始化为 0,作为存储最大数位和的 "擂台";

  3. 循环体中输入读取一个整数ai(用 long long 存储避免溢出);

  4. 对每个 ai 进行数位拆分,累加所有数位得到数位和 sum;

  5. 用数位和 sum 与 maxsum 打擂台:若 sum 更大,则更新 maxsum 为 sum;

  6. 所有数字处理完毕后,输出最终的最大数位和 maxsum;


【题解代码】

  1. 输入一个整数 n:代表接下来要输入 n 个整数;
cpp 复制代码
int n;
cin>>n;
int maxsum=0;// 擂台变量:保存当前最大的数位和,初始值为 0
  1. 循环 n 次,每次输入一个整数ai,数位拆分ai并计算数位和;
cpp 复制代码
while(n--){
    long long ai;
    cin>>ai;
    int sum=0;
    // 数位拆分:计算当前数字 ai 的数位和
    while(ai){ // 拆分ai的每一位,直到 ai 变为 0
        sum+=ai%10; // 取 ai 的个位数字,累加到数位和
        ai/=10;
    } 
    if(sum>maxsum){// 用ai的数位和与最大值打擂台 
        maxsum=sum;
    }
}
  1. 所有数字处理结束,输出最大数位和 ;
cpp 复制代码
cout<<maxsum;
相关推荐
赵民勇5 分钟前
gtkmm库之动作系统详解
linux·c++
宵时待雨7 分钟前
C++笔记归纳13:map & set
开发语言·数据结构·c++·笔记·算法
仰泳的熊猫5 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
Thera7779 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
君义_noip10 小时前
信息学奥赛一本通 1952:【10NOIP普及组】三国游戏 | 洛谷 P1199 [NOIP 2010 普及组] 三国游戏
c++·信息学奥赛·csp-s
旖-旎11 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
顶点多余11 小时前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
汉克老师11 小时前
GESP2026年3月认证C++四级( 第二部分判断题(1-10))
c++·指针·函数重载·文件操作·数组·gesp4级·gesp四级
khddvbe12 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
wWYy.13 小时前
STL:list
开发语言·c++