【腾讯2015校园招聘技术类】第24题

来源:互联网 发布:索引超出数组界限 编辑:程序博客网 时间:2024/06/10 00:33

题目:请设计一个函数可以把10进制的正整数转换为4位定长的36进制字符串

36进制的规则为:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

举例说明:

1="0001"

10="000A"

20="000k"

35="000Z"

36="0010"

100="002S"

2000="01JK"

代码如下

#include<iostream>
using namespace std;
char* tenTo36(int key)
{
  char *num36=new char[5];
  num36[0]=num36[1]=num36[2]=num36[3]='0';
  num36[4]='\0';
  int i=3;
  int tmp=key;
  while(i>=0&&tmp>0)
  {
     num36[i--]=(tmp%36>9)?('A'+tmp%36-10):('0'+tmp%36);
tmp=tmp/36;
  }
  return num36;
}
int main(void)
{
cout<<"输入十进制数"<<endl;
int key;
cin>>key;
char * tmp=new char[5];
tmp=tenTo36(key);
printf("%s\n",tmp);
return 0;
}

上面这种方法是一个很通用的方法:

那么下面对上面算法改进,使其适应任何进制

#include<iostream>
using namespace std;
char* tenTo36(int key)
{
printf("您要变成几进制(2到36进制)?\n");
int scale;
scanf("%d",&scale);
if(scale>=2&&scale<=10)
{
char *num36=new char[9];
for(int i=0;i<=7;i++)
num36[i]='0';
num36[8]='\0';
int i=7;
int tmp=key;
while(i>=0&&tmp>0)
{
num36[i--]='0'+tmp%scale;
tmp=tmp/scale;
}
return num36;
}
else
{
char *num36=new char[5];
for(int i=0;i<=3;i++)
num36[i]='0';
num36[4]='\0';
int i=3;
int tmp=key;
while(i>=0&&tmp>0)
{    
{
num36[i--]=(tmp%scale>9)?('A'+tmp%scale-10):('0'+tmp%scale);
tmp=tmp/scale;
}
}
return num36;
}

}
int main(void)
{
cout<<"输入十进制数"<<endl;
int key;
cin>>key;
char * tmp;
tmp=tenTo36(key);
printf("%s\n",tmp);
return 0;
}

0 0
原创粉丝点击