华为笔试——C++进制转换
程序员文章站
2022-07-05 14:38:58
题目:2-62进制转换 题目介绍:输入一个n1 进制的整数(包括负数),将其转换成n2 进制,其中n1 、n2 的范围是 [ 2,62 ] 。每个数字的范围是0-9、a-z、A-Z。不用考虑非法输入。 输入: n1 n2 n1 进制整数 输出: n2 进制整数 例: 输入: 8 16 -135246 ......
题目:2-62进制转换
题目介绍:输入一个n1 进制的整数(包括负数),将其转换成n2 进制,其中n1 、n2 的范围是 [ 2,62 ] 。每个数字的范围是0-9、a-z、a-z。不用考虑非法输入。
输入:
n1 n2
n1 进制整数
输出:
n2 进制整数
例:
输入:
8 16
-1352460
输出:
-5d530
分析:
这道题目需要考虑几点:负整数的输入;将输入的n1 进制的数转换成10 进制的数,再用长除法将这个10 进制的数转换成 n2 进制的数;a-z和a-z与其代表的整数的相互转换(char 类型的asc||码与整数的变换)。
代码如下:
1 #include <iostream> 2 #include <string> 3 #include <math.h> 4 #include <conio.h> 5 using namespace std; 6 int main() 7 { 8 string str; 9 int size; 10 int i = 0; 11 int result = 0; 12 int n = 0; 13 int r[10];//长除法 14 char q[10]; 15 int n1, n2; 16 cout << "n1.n2" << endl; 17 cin >> n1 >> n2; 18 cout << "str" << endl; 19 cin >> str; 20 size = str.size(); 21 char *p = new char[size]; 22 strcpy(p, str.c_str()); 23 if (p[0] == '-') { p[0] = '0'; }//考虑到负数 24 for (i = 0; i < size; i++) 25 { 26 if (p[i] >= 'a'&&p[i] <= 'z') 27 { 28 p[i] = p[i] - 39; 29 } 30 if (p[i] >= 'a'&&p[i] <= 'z') 31 { 32 p[i] = p[i] + 19; 33 } 34 }//将a-z的字符意义化a=10、··· 35 for (i = 0; i < size; i++) 36 { 37 result += int(p[i] - 48) * int(pow(n1, size - 38 39 1 - i)); 40 } 41 cout << result << endl;//计算十进制值 42 while ((result / n2) >= n2) 43 { 44 r[n] = result % n2; 45 result = result / n2; 46 n++; 47 } 48 r[n] = result % n2; 49 n++; 50 r[n] = result / n2;//取余取除值 51 for (i = 0; i < (n + 1); i++) 52 { 53 if (r[i] >= 10&&r[i]<=35) { q[i] = r[i]+87; }//a-z的输出转换 54 else if (r[i] >=36&&r[i]<=61) { q[i] = r[i]+29; }//a-z的输出转换 55 else { q[i] = char(r[i] + 48); }//0-9转换 56 } 57 if (p[0] == '0') { cout << "-"; }//负数还原 58 for (i = 0; i < (n + 1); i++) 59 { 60 cout << q[n - i]; 61 } 62 }
结果如图:其中输出的第二行为10 进制的该数。
上一篇: 我正趴床上玩手机
下一篇: 从无到有实现一个网页计算器
推荐阅读
-
华为笔试——C++字符串四则运算的实现
-
华为笔试——C++转换字符串问题
-
c++编写递归函数char *itostr (int n,char *string),该函数将整数n转换为十进制表示的字符串。
-
华为2017校招C++岗笔试题
-
1027 Colors in Mars (20分)——C/C++(进制转换)
-
C++ 十进制转换为十六进制 ,十进制转换为二进制,十六进制转换为十进制
-
C/C++ 十六进制转八进制 利用bitset预处理,将十进制转换为对应二进制数
-
【进制转换】如何使用C++将一个二进制数转为十进制?
-
Convert a Number to Hexadecimal(C++数字转换为十六进制数)
-
华为笔试——C++的int型数字位排序