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;             
相关推荐
tankeven4 小时前
HJ159 没挡住洪水
c++·算法
美式请加冰4 小时前
斐波那契数列介绍和使用
算法
charlie1145141914 小时前
嵌入式C++教程实战之Linux下的单片机编程:从零搭建 STM32 开发工具链(5):调试进阶篇 —— 从 printf 到完整 GDB 调试环境
linux·c++·单片机·学习·嵌入式·c
paeamecium4 小时前
【PAT】 - Course List for Student (25)
数据结构·c++·算法·pat考试
小黄人软件4 小时前
MFC为什么不报空指针异常 2宏定义不改源码 用替换 用Log函数替换printf等 #define printf Log 优化版底层类Log显示
c++·mfc
wen__xvn4 小时前
力扣洛谷模拟题刷题2
算法·leetcode·职场和发展
漫随流水4 小时前
c++编程:说反话(1009-PAT乙级)
数据结构·c++·算法
披着羊皮不是狼5 小时前
深度解构栈内存的物理逻辑与系统保护
数据结构··底层原理
计算机安禾5 小时前
【数据结构与算法】第23篇:树、森林与二叉树的转换
c语言·开发语言·数据结构·c++·线性代数·算法·矩阵