上海计算机学会 2023年11月月赛 丙组T3 数根(二)(高精度除法)

第三题:T3数根(二)

标签 :高精度除法
题意 :给定一个正整数 n n n,定义一个数字的根为它的十进制数字之和,例如 1234 1234 1234的数根为 1 + 2 + 3 + 4 1+2+3+4 1+2+3+4,请判定 n n n的数根能否整除 n n n。( 1 < = n < = 1 0 100000 1<=n<=10^{100000} 1<=n<=10100000)
题解 :高精度数以字符串形式输入,先求数根,最坏情况 99999 99999 99999位都是 9 9 9,显然数根是个低精度数。所以题目就转换成高精度数除于低精度数题目,最终看下取模的余数是否为 0 0 0,判断下能否整除即可。
代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {
    int m = 0, k = 0;
    string s;
    cin >> s;
    for (int i = 0; i < s.size(); i++) {
        m += (s[i] - '0');
    }

    for (int i = 0; i < s.size(); i++) {
        k = 10 * k + (s[i] - '0');
        k %= m;
    }

    if (k > 0) cout << "No";
    else cout << "Yes";
    return 0;
}
相关推荐
递归不收敛2 分钟前
config.json 完全指南:项目配置的核心实践
笔记·学习·json
不知几秋9 分钟前
配置JDK和MAVEN
java·开发语言·maven
没有bug.的程序员9 分钟前
Spring Cloud Gateway 路由与过滤器机制
java·开发语言·spring boot·spring·gateway
飞鱼&10 分钟前
java数据结构
数据结构·二叉树·散列表·红黑树
shenghaide_jiahu13 分钟前
字符串匹配和回文串类题目
学习·算法·动态规划
枫叶丹423 分钟前
【Qt开发】布局管理器(五)-> QSpacerItem 控件
开发语言·数据库·c++·qt
月下倩影时24 分钟前
ROS1基础入门:从零搭建机器人通信系统(Python/C++)
c++·python·机器人
_OP_CHEN27 分钟前
C++进阶:(八)基于红黑树泛型封装实现 map 与 set 容器
开发语言·c++·stl·set·map·红黑树·泛型编程
C1161135 分钟前
Jupyter中选择不同的python 虚拟环境
开发语言·人工智能·python
无敌最俊朗@40 分钟前
C++线程中detach和join的注意点
c++