蓝桥杯 基础练习 BASIC-12 十六进制转八进制

基础练习 十六进制转八进制

时间限制:1.0s   内存限制:512.0MB

问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。

输入格式
  输入的第一行为一个正整数n (1<=n<=10)。
  接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。

输出格式
  输出n行,每行为输入对应的八进制正整数。

  【注意
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。

样例输入
  2
  39
  123ABC

样例输出
  71
  4435274

  提示
  先将十六进制数转换成某进制数,再由某进制数转换成八进制。

示例代码:

 1 //十六进制转二进制,二进制转八进制
 2
 3 #include <iostream>
 4 #include <map>
 5 using namespace std;
 6
 7 int main() {
 8     string s;            //输入的十六进制
 9     string binaryNum;    //二进制数
10     int n;
11     cin >> n;
12
13     string str[16] = {"0000", "0001", "0010", "0011",
14                       "0100", "0101", "0110", "0111",
15                       "1000", "1001", "1010", "1011",
16                       "1100", "1101", "1110", "1111"};
17
18     map<string, string> m;
19     m["000"] = "0"; m["001"] = "1"; m["010"] = "2"; m["011"] = "3";
20     m["100"] = "4"; m["101"] = "5"; m["110"] = "6"; m["111"] = "7";
21
22     for (int i = 0; i < n; i++)
23     {
24         cin >> s;
25         int len_s = s.length();
26         for(int j = 0; j < len_s; j++)
27         {
28             if(s[j] > ‘9‘)
29             {
30                 binaryNum += str[s[j] - ‘A‘ + 10];
31             }
32             else
33             {
34                 binaryNum += str[s[j] - ‘0‘];
35             }
36         }
37
38         int len_b = binaryNum.length();            //二进制数的长度
39         if(len_b % 3 == 1)                         //将二进制的长度转为3的倍数
40         {
41             binaryNum = "00" + binaryNum;
42         }
43         else if(len_b % 3 == 2)
44         {
45             binaryNum = "0" + binaryNum;
46         }
47
48         int flag = 0;        //前导为0标志
49         string temp;        //获取三位二进制数,将其转为八进制
50         string octalNum;    //八进制数
51         for(int j = 0; j < len_b; j += 3)
52         {
53             temp = binaryNum.substr(j, 3);
54             octalNum = m[temp];
55             if(j == 0 && octalNum == "0")    //如果取出的二进制数前三位为0,则重新取接下来的3位二进制数
56             {
57                 flag = 1;
58                 continue;
59             }
60             if(flag == 1 && j == 3 && octalNum == "0") //如果接下来的二进制还为0,则继续取(后边取的肯定不是0)
61             {
62                 continue;
63             }
64             cout << octalNum;
65         }
66
67         cout << endl;
68         binaryNum = "";
69     }
70
71     return 0;
72 }
时间: 2024-10-18 15:33:57

蓝桥杯 基础练习 BASIC-12 十六进制转八进制的相关文章

蓝桥杯 基础练习 十进制转十六进制

基础练习 十进制转十六进制 时间限制:1.0s   内存限制:512.0MB 问题描述 十六进制数是在程序设计时经常要使用到的一种整数的表示方式.它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15.十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E. 给出一个非负整数,将它表示成十六进制的形式. 输入格式 输入包含一个非负整数a,表示要转换的数.0<

蓝桥杯——基础练习之分治法_快速排序

分治法,分而治之,基本思路:分,解,和. 初探分治之快速排序. public class _DividedConquer { static int[] iarr; public static void main(String[] args) { // TODO Auto-generated method stub iarr=new int[]{6,4,5,3,1,2}; quick(0, iarr.length-1); for(int i:iarr) { System.out.print(i+"

蓝桥杯——基础练习之FJ的字符串

问题描述 FJ在沙盘上写了这样一些字符串: A1 = "A" A2 = "ABA" A3 = "ABACABA" A4 = "ABACABADABACABA" - - 你能找出其中的规律并写所有的数列AN吗? 输入格式 仅有一个数:N ≤ 26. 输出格式 请输出相应的字符串AN,以一个换行符结束.输出中不得含有多余的空格或换行.回车符. 样例输入 3 样例输出 ABACABA public static void main(

蓝桥杯—— 基础练习之Sine之舞

问题描述 最近FJ为他的奶牛们开设了数学分析课,FJ知道若要学好这门课,必须有一个好的三角函数基本功.所以他准备和奶牛们做一个"Sine之舞"的游戏,寓教于乐,提高奶牛们的计算能力. 不妨设 An=sin(1–sin(2+sin(3–sin(4+...sin(n))...) Sn=(...(A1+n)A2+n-1)A3+...+2)An+1 FJ想让奶牛们计算Sn的值,请你帮助FJ打印出Sn的完整表达式,以方便奶牛们做题. 输入格式 仅有一个数:N<201. 输出格式 请输出相应

蓝桥杯-基础练习-十六进制转八进制(被超时了!!!)

基础练习 十六进制转八进制 时间限制:1.0s   内存限制:512.0MB 问题描述 给定n个十六进制正整数,输出它们对应的八进制数. 输入格式 输入的第一行为一个正整数n (1<=n<=10). 接下来n行,每行一个由0~9.大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000. 输出格式 输出n行,每行为输入对应的八进制正整数. 注意 输入的十六进制数不会有前导0,比如012A. 输出的八进制数也不能有前导0. 样例输入 2 39 123ABC 样

蓝桥杯 基础练习 十六进制转八进制 【字符串处理】

  基础练习 十六进制转八进制   时间限制:1.0s   内存限制:512.0MB      问题描述 给定n个十六进制正整数,输出它们对应的八进制数. 输入格式 输入的第一行为一个正整数n (1<=n<=10). 接下来n行,每行一个由0~9.大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000. 输出格式 输出n行,每行为输入对应的八进制正整数. 注意 输入的十六进制数不会有前导0,比如012A. 输出的八进制数也不能有前导0. 样例输入 2 39

蓝桥杯 基础练习 十六进制转八进制

问题描述 给定n个十六进制正整数,输出它们对应的八进制数. 输入格式 输入的第一行为一个正整数n (1<=n<=10). 接下来n行,每行一个由0~9.大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000. 输出格式 输出n行,每行为输入对应的八进制正整数. [注意] 输入的十六进制数不会有前导0,比如012A. 输出的八进制数也不能有前导0. 样例输入 2 39 123ABC 样例输出 71 4435274 [提示] 先将十六进制数转换成某进制数,再由

蓝桥杯 基础练习 十六进制转十进制

基础练习 十六进制转十进制 时间限制:1.0s   内存限制:512.0MB 问题描述 从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出. 注:十六进制数中的10~15分别用大写的英文字母A.B.C.D.E.F表示. 样例输入 FFFF 样例输出 65535 16进制转10进制  例:8A5F=16^3*8+16^2*10+16^1*5+16^0*15: #include<stdio.h> #include<string.h> #include<s

蓝桥杯- 基础练习:十六进制转八进制

import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int size = scanner.nextInt(); String[] strings = new String[size]; for (int i = 0; i < strings.length; i++) { strings[i]