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;
相关推荐
郝学胜_神的一滴1 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
卷无止境3 天前
C++ 的Eigen 库全解析
c++
卷无止境3 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴3 天前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
博客18005 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴5 天前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
众少成多积小致巨6 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
clint45610 天前
C++进阶(1)——前景提要
c++
夜悊10 天前
C++代码示例:进制数简单生成工具
c++
郝学胜_神的一滴10 天前
CMake 021: IF 条件判据详诠
c++·cmake