站在前辈们的肩膀上,T_T将进制间的转换摸索出来了~并且补充了完整版的
--------仅供自己以后复习使用-----------
/*
s[]: 原进制数字,用字符串表示
s2[]: 转换结果,用字符串表示
d1: 原进制数
d2: 需要转换到的进制数
返回值: null
*/
#include<cstdio>
#include<cmath>
#include<algorithm>
#include <string.h>
#include <iostream>
using namespace std;
void conversion(char s[],char s2[],long d1,long d2)
{
long i,j,t,num;
char c;
num=0;
for (i=0;s[i]!='\0';i++)
{
if (s[i]<='9'&&s[i]>='0') t=s[i]-'0'; else t=s[i]-'A'+10;
num=num*d1+t;
}
i=0;
while(1)
{
t=num%d2;
if (t<=9) s2[i]=t+'0'; else s2[i]=t+'A'-10;
num/=d2;
if (num==0) break;
i++;
}
//for (j=0;j<i/2;j++)
// {c=s2[j];s2[j]=s[i-j];s2[i-j]=c;}逻辑推理了一下觉得此处的代码不太对 有错之处还请指出
s2[i+1]='\0';
for(int k=i;k>=0;k--)
printf("%c",s2[k]); //逆输出
}
int main()
{
char s[100000],s2[100000];
strcpy(s,"23456");//可以使用用strcpy()函数方便赋值//cin>>s
long d1=10,d2=2;
conversion(s,s2,d1,d2);
return 0;
}