c++编程:D进制的A+B(1022-PAT乙级)

1022. D进制的A+B

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

int main() {               
    int A, B, D;             // 定义三个整数变量 A、B 和进制 D
    cin >> A >> B >> D;      // 从标准输入读取 A、B、D 的值
    
    int sum = A + B;         // 计算 A 和 B 的和,存入 sum
    
    // 处理 sum = 0 的特殊情况
    if(sum == 0) {           // 如果和为 0
        cout << 0 << endl;   // 直接输出 0(0 的任何进制表示都是 0)
        return 0;            // 程序结束
    }
    
    stack<int> s;            // 创建一个整型栈 s,用于存储进制转换后的每一位
    
    // 除 D 取余法:将 sum 转换为 D 进制
    while(sum) {             // 当 sum 不为 0 时循环
        s.push(sum % D);     // 计算 sum 除以 D 的余数,压入栈中
        sum /= D;            // sum 整除 D,准备处理下一位
    }
    // 循环结束后,栈中从栈底到栈顶存储的是 D 进制数的低位到高位(逆序)
    
    // 出栈输出:从高位到低位依次输出
    while(!s.empty()) {      // 当栈不为空时循环
        int digit = s.top(); // 获取栈顶元素(当前最高位)
        s.pop();             // 弹出栈顶元素
        
        // 判断是否需要输出字母(针对十六进制等大于 10 的进制)
        if(digit < 10) {     // 如果数字小于 10
            cout << digit;   // 直接输出数字(0-9)
        } else {             // 如果数字大于等于 10(即 10-15)
            // 转换为对应字母:10→A, 11→B, 12→C, 13→D, 14→E, 15→F
            cout << char(digit - 10 + 'A');
        }
    }         
    
    return 0;             
相关推荐
王璐WL9 分钟前
【C++】类的默认成员函数(上)
c++
Robot_Nav16 分钟前
TD3 —— 双延迟深度确定性策略梯度算法文献解读
算法·td3·drl
斯维赤17 分钟前
每天学习一个小算法:归并排序
学习·算法·排序算法
王老师青少年编程23 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【区间贪心】:区间覆盖(加强版)
c++·算法·贪心·csp·信奥赛·区间贪心·区间覆盖(加强版)
碧海银沙音频科技研究院29 分钟前
杰理项目开发大全课程
人工智能·深度学习·算法
宏笋1 小时前
C++11完美转发的作用和用法
c++
格发许可优化管理系统1 小时前
MathCAD许可类型全面解析:选择最适合您的许可证
c++
风一样的航哥1 小时前
LeetCode 2615 等值距离和:前缀和优化O(n)解法深度解析
数据结构·算法·leetcode
生成论实验室1 小时前
生成态势猜想:一种统一的宇宙动力学语法
人工智能·科技·神经网络·算法·信息与通信
旖-旎2 小时前
深搜(二叉树的所有路径)(6)
c++·算法·leetcode·深度优先·递归