[保研/考研机试] KY26 10进制 VS 2进制 清华大学复试上机题 C++实现

题目链接:

10进制 VS 2进制http://www.nowcoder.com/share/jump/437195121691738172415

描述

对于一个十进制数A,将A转换为二进制数,然后按位逆序排列,再转换为十进制数B,我们称B为A的二进制逆序数。 例如对于十进制数173,它的二进制形式为10101101,逆序排列得到10110101,其十进制数为181,181即为173的二进制逆序数。

输入描述:

一个1000位(即10^999)以内的十进制数。

输出描述:

输入的十进制数的二进制逆序数。

示例1

输入:

173

输出:

181

思路:

  1. 输入一个十进制数 s
  2. 使用大整数除法函数 divides 不断除以 2,得到二进制数的各个位,存放在向量 binary 中,顺序是按位逆序排列的。
  3. 初始化一个字符串 res 为 "0",用于存放最终的结果。
  4. 遍历 binary 中的每一位,将 res 乘以 2(相当于左移一位),然后加上当前位的值,得到二进制逆序数的十进制表示。
  5. 输出最终的二进制逆序数。

注意:代码中使用了字符串来表示大整数,通过模拟除法、乘法和加法操作,实现了对二进制逆序数的计算和转换。

源代码:

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

// 例题6.3 KY26 10进制 VS 2进制 

// 字符串表示的大整数除法
string divide(string str, int x) {
    int reminder = 0;  // 余数
    for (int i = 0; i < str.size(); i++) {
        int current = reminder * 10 + str[i] - '0';  // 当前位的数值
        str[i] = current / x + '0';  // 更新当前位的值为商的字符表示
        reminder = current % x;  // 更新余数
    }
    int pos = 0;
    while (str[pos] == '0') {
        pos++;  // 移除前导零
    }
    return str.substr(pos);  // 返回除法结果,移除前导零
}

string multiple(string str, int x) {
    int carry = 0;  // 进位
    for (int i = str.size() - 1; i >= 0; i--) {
        int current = x * (str[i] - '0') + carry;  // 当前位的计算结果
        str[i] = current % 10 + '0';  // 更新当前位的值为计算结果的个位
        carry = current / 10;  // 更新进位
    }
    if (carry != 0) {
        str = "1" + str;  // 处理最终的进位
    }
    return str;
}

string Add(string str, int x) {
    int carry = x;  // 初始进位为 x
    for (int i = str.size() - 1; i >= 0; i--) {
        int current = (str[i] - '0') + carry;  // 当前位的计算结果
        str[i] = current % 10 + '0';  // 更新当前位的值为计算结果的个位
        carry = current / 10;  // 更新进位
    }
    if (carry != 0) {
        str = "1" + str;  // 处理最终的进位
    }
    return str;
}

int main() {
    string s;
    cin >> s;  // 输入十进制数
    vector<int> binary;  // 用于存放二进制逆序的每一位
    while (s.size() != 0) {
        int last = s[s.size() - 1] - '0';  // 取最后一位
        binary.push_back(last % 2);  // 将最后一位的余数(二进制的最低位)存入 vector
        s = divide(s, 2);  // 将十进制数除以 2,得到下一轮迭代的数值
    }

    // 将得到的 binary 中的按位逆序排列的二进制数转换为十进制数
    string res = "0";  // 初始化结果为 0
    for (int i = 0; i < binary.size(); i++) {
        res = multiple(res, 2);  // 将结果乘以 2,相当于左移一位
        res = Add(res, binary[i]);  // 加上当前位的值
    }
    cout << res << endl;  // 输出最终的二进制逆序数
   
    return 0;
}

提交结果:

相关推荐
cherub.1 分钟前
深入解析信号量:定义与环形队列生产消费模型剖析
linux·c++
机器学习之心3 分钟前
一区北方苍鹰算法优化+创新改进Transformer!NGO-Transformer-LSTM多变量回归预测
算法·lstm·transformer·北方苍鹰算法优化·多变量回归预测·ngo-transformer
yyt_cdeyyds14 分钟前
FIFO和LRU算法实现操作系统中主存管理
算法
暮色_年华15 分钟前
Modern Effective C++item 9:优先考虑别名声明而非typedef
c++
重生之我是数学王子23 分钟前
QT基础 编码问题 定时器 事件 绘图事件 keyPressEvent QT5.12.3环境 C++实现
开发语言·c++·qt
daiyang123...36 分钟前
测试岗位应该学什么
数据结构
alphaTao40 分钟前
LeetCode 每日一题 2024/11/18-2024/11/24
算法·leetcode
我们的五年1 小时前
【Linux课程学习】:进程程序替换,execl,execv,execlp,execvp,execve,execle,execvpe函数
linux·c++·学习
kitesxian1 小时前
Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)
数据结构·算法·leetcode
做人不要太理性1 小时前
【C++】深入哈希表核心:从改造到封装,解锁 unordered_set 与 unordered_map 的终极奥义!
c++·哈希算法·散列表·unordered_map·unordered_set