admin管理员组

文章数量:1794759

第十三届蓝桥杯B组C++(试题A:九进制转十进制)

第十三届蓝桥杯B组C++(试题A:九进制转十进制)

试题A:九进制转十进制

简介:本题考点为进制转换,较为简单,参考二进制转换为十进制的方法。

二进制转十进制操作

二进制转为十进制的时候,先把二进制从高位(最左边的“1”)开始按从上到下的顺序写出 ,第一位就是最后的商 “2 2 = 1 余0 “,余数肯定是加零。其他位数如果有”1“(原来的余数),就先乘以”2“再加”1“。 下面就是从第一位开始乘以2加余数的方法算回去 例如 100101110 1…………0 2+1=1…………余数为1 0…………1 2+0=2………… 余数为0 0 …………2 2+0=4 ………… 余数为0 1 …………4x2+1=9……………… 余数为1 0…………9x2+0=18 ……………… 余数为0 1 …………18 2+1=37 …………余数为1 1…………… 37 2+1=75…………余数为1 1………………75 2+1=151………… 余数为1 0………………151 2+0=302 ………… 余0 所以得到十进制数302 另:128+0*27+026+1*25+024+1*23+122+1*21+0=302(最后一位应为加法)

题解:

#include<iostream> using namespace std; // 原理与二进制相同 int main() { int x = 2022; int a = 1; // 九进制数的每一位需要乘的数字 int res = 0; while(x) { res += (x % 10) * a; a = a * 9; x /= 10; } cout << res; return 0; }

答案为:1478

本文标签: 试题第十三届蓝桥杯九进制转十进制