[保研/考研机试] KY80 进制转换 北京大学复试上机题 C++实现

题目链接:

KY80 进制转换https://www.nowcoder.com/share/jump/437195121691735660774

描述

写出一个程序,接受一个十六进制的数值字符串,输出该数值的十进制字符串(注意可能存在的一个测试用例里的多组数据)。

输入描述:

输入一个十六进制的数值字符串。

输出描述:

输出该数值的十进制字符串。

示例1

输入:

cpp 复制代码
0xA

输出:

cpp 复制代码
10

思路:

  1. 读入十六进制数值字符串 s。

  2. 初始化结果字符串 res 为 "0",表示最终的十进制结果。

  3. 从字符串的第三位开始遍历,即从十六进制数值的有效部分开始,因为前两位为 "0x" 表示十六进制前缀。

  4. 在遍历过程中,先将结果字符串 res 乘以 16,相当于将十六进制数值左移 4 位。

  5. 再将当前字符代表的值加到结果字符串 res 中,通过调用 Add 函数实现。

  6. 输出最终的十进制结果。

源代码:

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

// 将十六进制字符转换为对应的整数
int CharToInt(char c) {
    if (c >= '0' && c <= '9') {
        return c - '0';  // 数字字符直接转换
    } else {
        return c - 'A' + 10;  // 字母字符转换,a 对应 10,b 对应 11,依此类推
    }
}

// 将字符串表示的十六进制数与整数 x 相乘
string multiple(string str, int x) {
    int carry = 0;  // 进位
    string result;  // 存放结果
    for (int i = str.size() - 1; i >= 0; i--) {
        int current = x * CharToInt(str[i]) + carry; // 计算当前位的结果
        result = char(current % 10 + '0') + result;  // 将当前位的结果插入到结果的前面
        carry = current / 10;  // 更新进位
    }
    while (carry != 0) {
        result = char(carry % 10 + '0') + result;  // 处理剩余的进位
        carry /= 10;
    }
    return result;
}

// 将字符串表示的十六进制数与整数 x 相加
string Add(string str, int x) {
    int carry = x;  // 初始进位为 x
    string result;  // 存放结果
    for (int i = str.size() - 1; i >= 0; i--) {
        int current = CharToInt(str[i]) + carry; // 计算当前位的结果
        result = char(current % 10 + '0') + result;  // 将当前位的结果插入到结果的前面
        carry = current / 10;  // 更新进位
    }
    while (carry != 0) {
        result = char(carry % 10 + '0') + result;  // 处理剩余的进位
        carry /= 10;
    }
    return result;
}

int main() {
    string s;
    while (cin >> s) {
        string res = "0";  // 初始化结果为0
        for (int i = 2; i < s.size(); i++) {
            res = multiple(res, 16);  // 乘以16,相当于左移4位
            res = Add(res, CharToInt(s[i]));  // 加上当前字符代表的值
        }
        cout << res << endl;  // 输出最终结果
    }

    return 0;
}

提交结果:

编辑切换为居中

添加图片注释,不超过 140 字(可选)

相关推荐
qeen879 小时前
【算法笔记】各种常见排序算法详细解析(上)
c语言·数据结构·c++·学习·算法·排序算法
史迪仔01129 小时前
[QML] Qt5/6图像色彩空间处理
开发语言·前端·c++·qt
每天回答3个问题9 小时前
LeetCodeHot100|图、994.腐烂的橘子、207.课程表、208.实现Trie前缀树
c++·
如君愿9 小时前
考研复习 Day 36 | 习题--计算机网络 第七章 网络安全(下)、数据结构 排序算法(下)
计算机网络·考研·web安全
许长安9 小时前
gRPC 数据包传输格式解析:从 Protobuf 到 HTTP/2
c++·经验分享·笔记·http·rpc
渡我白衣10 小时前
定时器与时间轮思想
linux·开发语言·前端·c++·人工智能·深度学习·神经网络
luyun02020210 小时前
实用小工具,吾爱出品
开发语言·c++·算法
蜡笔小马10 小时前
06.C++设计模式-装饰模式
c++·设计模式·装饰器模式
宏笋10 小时前
C++11使用chrono获取当前时间戳
c++
Shadow(⊙o⊙)10 小时前
硬核手搓解析!进程-内核分析:命令行参数及环境变量,重构main()
linux·运维·服务器·开发语言·c++·后端·学习