admin管理员组文章数量:1794759
第十三届蓝桥杯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
版权声明:本文标题:第十三届蓝桥杯B组C++(试题A:九进制转十进制) 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1686579261a83970.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论