• 十进制转任意进制


    各位亲:

      下午没事就记录了十进制转换成其他任意进制算法完整代码实现如下,基本原理运用辗转相除法。

      1 #include<iostream>
      2 #include<cstring>
      3 #include<string>
      4 #include<string.h>
      5 #include<stdio.h>
      6 #include <algorithm>
      7 using namespace std;
      8 
      9 string JinZhi10To2Str(int n)
     10 {
     11     int i;
     12     string temp = "";
     13     string value = "";
     14     i = n;
     15     while (i) {
     16         //_itoa_s(i % 2,str,10);
     17         temp = to_string(i % 2);
     18         value = temp + value; //倒叙拼接
     19         i /= 2;
     20     }
     21     return value;
     22 }
     23 
     24 string JinZhi10To8Str(int n)
     25 {
     26     int i;
     27     string value = "";
     28     string temp = "";
     29     i = n;
     30     while (i)
     31     {
     32         temp = to_string(i % 8);
     33         value = temp + value;
     34         i /= 8;
     35     }
     36     return value;
     37 }
     38 
     39 string JinZhi10To16Str(int n)
     40 {
     41     int i;
     42     string value = "";
     43     string temp = "";
     44     i = n;
     45     while (i) {
     46         int m = i % 16;
     47         if (m >= 10) {
     48             switch (m)
     49             {
     50             case 10:temp = "A"; break;
     51             case 11:temp = "B"; break;
     52             case 12:temp = "C"; break;
     53             case 13:temp = "D"; break;
     54             case 14:temp = "E"; break;
     55             case 15:temp = "F"; break;
     56             default:
     57                 break;
     58             }
     59             value = temp + value;
     60         }
     61         else {
     62             temp = to_string(m);
     63             value = temp + value;
     64         }
     65         i /= 16;
     66     }
     67     return value;
     68 }
     69 
     70 string JinZhi10To32Str(int n)
     71 {
     72     string value;
     73     string tmp;
     74     
     75     char str[100];
     76     for (int i = 3; i >= 0; i--)
     77     {
     78         int a = 1;
     79         switch (i)
     80         {
     81         case 1: a = 32; break;
     82         case 2: a = 32 * 32; break;
     83         case 3: a = 32 * 32 * 32; break;
     84         }
     85 
     86         tmp = "";
     87         int b = n / a;
     88         if (b <= 0x0f)
     89         {
     90 
     91             _itoa_s(b, str, 16);
     92             string s(&str[0], &str[strlen(str)]);
     93             transform(s.begin(), s.end(), s.begin(), ::toupper);//转换成大写字母
     94             //transform(str.begin(), str.end(), str.begin(), ::tolower); //转换成小写字母
     95             tmp = s;
     96 
     97             //tmp = to_string(b);//可以直接将整型转换成字符串类型包含于#include<string>
     98 
     99         #if 0
    100             tmp.format("%x", b); //mfc中格式化16进制输出
    101         #endif
    102 
    103         }
    104         else
    105         {
    106             // g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v
    107             switch (b)
    108             {
    109             case 16:tmp = "G"; break;
    110             case 17:tmp = "H"; break;
    111             case 18:tmp = "J"; break;
    112             case 19:tmp = "K"; break;
    113             case 20:tmp = "L"; break;
    114             case 21:tmp = "M"; break;
    115             case 22:tmp = "N"; break;
    116             case 23:tmp = "P"; break;
    117             case 24:tmp = "R"; break;
    118             case 25:tmp = "S"; break;
    119             case 26:tmp = "T"; break;
    120             case 27:tmp = "V"; break;
    121             case 28:tmp = "W"; break;
    122             case 29:tmp = "X"; break;
    123             case 30:tmp = "Y"; break;
    124             case 31:tmp = "Z"; break;
    125             default:tmp = ""; break;
    126             }
    127         }
    128         value += tmp;
    129         n %= a;
    130     }
    131     return value;
    132 }
    133 
    134 string JinZhi10To32Str_1(int n)
    135 {
    136     int i;
    137     string value = "";
    138     string temp = "";
    139     i = n;
    140     while (i) {
    141         int m = i % 32;
    142         if (m >= 10) {
    143             switch (m)
    144             {
    145             case 10:temp = "A"; break;
    146             case 11:temp = "B"; break;
    147             case 12:temp = "C"; break;
    148             case 13:temp = "D"; break;
    149             case 14:temp = "E"; break;
    150             case 15:temp = "F"; break;
    151             case 16:temp = "G"; break;
    152             case 17:temp = "H"; break;
    153             case 18:temp = "I"; break;
    154             case 19:temp = "J"; break;
    155             case 20:temp = "K"; break;
    156             case 21:temp = "L"; break;
    157             case 22:temp = "M"; break;
    158             case 23:temp = "N"; break;
    159             case 24:temp = "O"; break;
    160             case 25:temp = "P"; break;
    161             case 26:temp = "Q"; break;
    162             case 27:temp = "R"; break;
    163             case 28:temp = "S"; break;
    164             case 29:temp = "T"; break;
    165             case 30:temp = "U"; break;
    166             case 31:temp = "V"; break;
    167             default:
    168                 break;
    169             }
    170             value = temp + value;
    171         }
    172         else {
    173             temp = to_string(m);
    174             value = temp + value;
    175         }
    176         i /= 32;
    177     }
    178     return value;
    179 }
    180 
    181 int main() 
    182 {
    183     int m,temp;
    184     while (true) {
    185         cout << endl << "  * * * * * * * * 进制转换 * * * * * * * *" << endl;
    186         cout << "  *                                      *" << endl;
    187         cout << "  *       1、10进制转2进制               *" << endl;
    188         cout << "  *                                      *" << endl;
    189         cout << "  *       2、10进制转8进制               *" << endl;
    190         cout << "  *                                      *" << endl;
    191         cout << "  *       3、10进制转16进制              *" << endl;
    192         cout << "  *                                      *" << endl;
    193         cout << "  *       4、10进制转32进制(i,o,u,v除外) *" << endl;
    194         cout << "  *                                      *" << endl;
    195         cout << "  *       5、10进制转32进制              *" << endl;
    196         cout << "  *                                      *" << endl;
    197         cout << "  * * * * * * * * * * * * * * * * * * * **" << endl << endl;
    198         cout << "  请选择:";
    199         cin >> m;
    200         switch (m)
    201         {
    202         case 1:
    203             cout << "十进制数:";
    204             cin >> temp;
    205             cout << temp << "转换成2进制:" << JinZhi10To2Str(temp) << endl << endl;
    206             break;
    207         case 2:
    208             cout << "十进制数:";
    209             cin >> temp;
    210             cout << temp << "转换成8进制:" << JinZhi10To8Str(temp) << endl << endl;
    211             break;
    212         case 3:
    213             cout << "十进制数:";
    214             cin >> temp;
    215             cout << temp << "转成16进制:" << JinZhi10To16Str(temp) << endl << endl;
    216             break;
    217         case 4:
    218             cout << "十进制数:";
    219             cin >> temp;
    220             cout << temp << "转换成32进制:" << JinZhi10To32Str(temp) << endl << endl;
    221             break;
    222         case 5:
    223             cout << "十进制数:";
    224             cin >> temp;
    225             cout << temp << "转换成32进制:" << JinZhi10To32Str_1(temp) << endl << endl;
    226             break;
    227         default:
    228             cout << "只能在1-6中选择" << endl;
    229             break;
    230         }
    231     }
    232 }
    233 
    234 
    235 #if 0
    236 
    237 #include<cstdio> 
    238 #include<cstdlib> 
    239 int main()
    240 {
    241     int num = 32;
    242     char str[100];
    243     _itoa_s(num, str, 32);  //c++中一般用_itoa,用itoa也行,
    244     printf("%s
    ", str);
    245     return 0;
    246 }
    247 
    248 
    249 #include<iostream>
    250 using namespace std;
    251 void main()
    252 {
    253     int n, i, j = 0;
    254     int a[1000];
    255     cin >> n;
    256     i = n;
    257     while (i)
    258     {
    259         a[j] = i % 2;
    260         i /= 2;
    261         j++;
    262 
    263     }
    264     for (i = j - 1; i >= 0; i--)
    265         cout << a[i];
    266     cout << endl;
    267 }
    268 #endif

    运行截图:

                

            

     

  • 相关阅读:
    整理:分页存储过程整理
    净利润-流通市值比率”与公司估值
    常见7种股票底部形态(图解)
    nginx
    移动成本分布1
    浅谈公开信息检索和判断能力
    股票技术分析 成交量与换手率专题
    成份股和成份股指数
    股票底部形态初探
    筹码拉抬派发法
  • 原文地址:https://www.cnblogs.com/geziyu/p/14046317.html
Copyright © 2020-2023  润新知