蓝桥杯 基础练习 十六进制转八进制
来源:互联网 发布:js防水涂料做法 编辑:程序博客网 时间:2024/06/03 15:26
问题描述
给定n个十六进制正整数,输出它们对应的八进制数。
输入格式
输入的第一行为一个正整数n (1<=n<=10)。
接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
输出格式
输出n行,每行为输入对应的八进制正整数。
【注意】
输入的十六进制数不会有前导0,比如012A。
输出的八进制数也不能有前导0。
样例输入
2
39
123ABC
样例输出
71
4435274
【提示】
先将十六进制数转换成某进制数,再由某进制数转换成八进制。
ps:注意前导0的添加与删除
#include <iostream>#include <map>using namespace std;int main() { string b, s, a; int n; cin >> n; string arr[16] = {"0000", "0001", "0010", "0011", "0100", "0101", "0110", "0111", "1000", "1001", "1010", "1011", "1100", "1101", "1110", "1111"}; map<string, string> m; m["000"] = "0"; m["001"] = "1"; m["010"] = "2"; m["011"] = "3"; m["100"] = "4"; m["101"] = "5"; m["110"] = "6"; m["111"] = "7"; for(int i = 0; i < n; i++) { cin >> s; int lens = s.length(); for(int j = 0; j < lens; j++) { if(s[j] > '9') { b += arr[s[j] - 'A' + 10]; } else { b += arr[s[j] - '0']; } } int lenb = b.length(); if(lenb % 3 == 1) { b = "00" + b; } else if(lenb % 3 == 2) { b = "0" + b; } int flag = 0; for(int j = 0; j < lenb; j += 3) { string temp = b.substr(j, 3); string t = m[temp]; if(j == 0 && t == "0") { flag = 1; continue; } if(flag == 1 && j == 3 && t == "0") { continue; } cout << t; } cout << endl; b = ""; } return 0;}
阅读全文
0 0
- 蓝桥杯:基础练习 十六进制转八进制
- "蓝桥杯“基础练习:十六进制转八进制
- 蓝桥杯 【基础练习】 十六进制转八进制
- 蓝桥杯:基础练习 十六进制转八进制
- 蓝桥杯基础练习--十六进制转八进制
- 【蓝桥杯】基础练习 十六进制转八进制
- 蓝桥杯基础练习 十六进制转八进制
- 基础练习-十六进制转八进制 -JAVA蓝桥杯
- 1501091239-蓝桥杯-基础练习 十六进制转八进制
- 蓝桥杯 基础练习 十六进制转八进制
- 蓝桥杯_ 基础练习 十六进制转八进制
- "蓝桥杯“基础练习:十六进制转八进制
- 蓝桥杯-基础练习12 十六进制转八进制
- 蓝桥杯-基础练习-十六进制转八进制
- 蓝桥杯:基础练习 十六进制转八进制
- 蓝桥杯 基础练习 十六进制转八进制
- 蓝桥杯 基础练习 十六进制转八进制
- 【蓝桥杯】【基础练习02】【十六进制转八进制】
- 搞不清FastCgi与PHP-fpm之间是个什么样的关系
- 初识CSS——关于布局
- 基于LinuxC下的停车场项目
- 快速排序
- fstat函数及struct stat结构
- 蓝桥杯 基础练习 十六进制转八进制
- 面向对象-结婚实例
- RN导入高德地图定位的用法实例
- 团体程序设计天梯赛-练习集 L1-035. 情人节
- Spring Cloud分布式微服务云架构—源码结构图
- 遮挡查询
- [Leetcode] 488. Zuma Game 解题报告
- springboot源码分析8-环境属性构造过程(下)
- RN中调用原生的分享功能(UIActivityViewController)