安南


私信TA

用户名:dotcpp0682916

访问量:129

签 名:

等  级
排  名 63845
经  验 205
参赛次数 0
文章发表 1
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

p进制转换q进制
浏览:113

解题思路:

注意事项:

参考代码:

#include<iostream>

#include<cstring>


using namespace std;


int m;

char c[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J',

'K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};

char n[51];

int a[51],b[1000000];

int main()

{

  cin>>m;

  while(m--){

      int p,q;

      scanf("%d",&p);

      getchar();//读掉逗号

      int in=0; char ch;

  while((ch=getchar())!=',')   n[in++]=ch;

  n[in]='\0';

      scanf("%d",&q);

      //读取数据


      int len=strlen(n);

      for(int i=0;i<len;i++){

         a[i]=n[i]>'9'?n[i]-'A'+10:n[i]-'0';

      }

      //把数据转化为整数类型并储存在a数组中


      int idx=0,flag=1;//idx是答案位数,最后按c[b[i]]输出

      while(1){

          int ans=0,t=0;

          for(int i=0;i<len;i++){

              ans=(a[i]+t*p)%q;

              a[i]=(a[i]+t*p)/q;

              t=ans;

          }

          b[idx++]=ans;

          //进制转换

           for (int i = 0; i < len; ++i) {//遍历查看是否还有数字不为0的情况

                if(a[i]!=0){

                    flag=0;

                    break;

                }

                flag=1;

            }

            if(flag)break;

      }

//输出

      for(int i=idx-1;i>=0;i--)cout<<c[b[i]];

      cout<<endl;

  }

    return 0;

}


 

0.0分

0 人评分

  评论区

  • «
  • »