• HOJ:2031 进制转换


    进制转换

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 18495    Accepted Submission(s): 10386


    Problem Description
    输入一个十进制数N,将它转换成R进制数输出。
     
    Input
    输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<>10)。
     
    Output
    为每个测试实例输出转换后的数,每个输出占一行。如果R大于10,则对应的数字规则参考16进制(比如,10用A表示,等等)。
     
    Sample Input
    7 2 23 12 -4 3
     
    Sample Output
    111 1B -11
     
     
    解题思路: 
    以第一个例子 7 2
    7%2=1
    7/2=3
    3%2=1
    3/2=1
    1%2=1
    1/2=0   //结束
    结果是111
    我的代码:
     1 #include <stdio.h>
     2 char A[100];
     3 int main()
     4 {
     5     int num,r,i,t,j,mark;
     6     while(~scanf("%d%d",&num,&r)){
     7         i=0;
     8         mark=0;
     9         if(num<0){
    10             mark=1;
    11             num=-num;
    12         }
    13         while(num>0){
    14             t=num%r;
    15             if(t>9)    A[i]= t-10+'A';
    16             else    A[i]= t+'0';    
    17             ++i;
    18             num/=r;
    19         }
    20         if(mark==1) printf("-");
    21 
    22         for(j=i-1;j>=0;j--){
    23             printf("%c", A[j]);
    24         }
    25         printf("
    ");
    26     }
    27     return 0;
    28 }

    大神级别代码:

     1 #include <stdio.h>
     2 #include <string.h>
     3 
     4 void ttor(int n, int r)
     5 {
     6     if (n)
     7     {
     8         ttor(n / r, r);
     9         printf("%c", n % r > 9 ? n % r - 10 + 'A' : n % r + '0');
    10     }
    11 }
    12 
    13 int main(void)
    14 {
    15     int n;
    16     int r;
    17 
    18     while (scanf("%d%d", &n, &r) != EOF)
    19     {
    20         if (n > 0)
    21             ttor(n, r);
    22         else if (!n)//表示n==0
    23             putchar('0');
    24         else
    25         {
    26             putchar('-');
    27             ttor(-n, r);
    28         }
    29         putchar('
    ');
    30     }
    31 
    32     return 0;
    33 }
     
  • 相关阅读:
    UI控件
    iOS 上架
    UISwitch 开关
    UISlider 的属性
    SQL SERVER 触发器
    sql server数据库操作
    二叉堆实现优先队列
    散列表
    AVL树
    C++基础-02
  • 原文地址:https://www.cnblogs.com/firstrate/p/3197159.html
Copyright © 2020-2023  润新知