紫竹


私信TA

用户名:urnachan

访问量:30202

签 名:

等  级
排  名 305
经  验 5576
参赛次数 0
文章发表 72
年  龄 0
在职情况 学生
学  校 合肥工业大学
专  业

  自我简介:

TA的其他文章

// 进制为M数值n → 进制N后的结果  (2~16)


#include "stdafx.h"

#include "string.h"

#define M 10

#define N 8

int stoi(char a)

{

if (a >= '0'&&a <= '9')

return a - '0';

else if (a >= 'a'&&a <= 'f')

return a - 'a';

else if (a >= 'A'&&a <= 'F')

return a - 'A';

}

char itos(int a)

{

char x[17] = "0123456789ABCDEF";

return x[a];

}

int aToten(int a,int len,char x[])

{

int i,t=1, sum=0;

for (i = len - 1; i >=0; i--)

{

sum += t * stoi(x[i]);

t *= a;

}

return sum;

}

void Reverse(char* s, int left, int right)

{

if (left >= right)

return;


char t = s[left];

s[left] = s[right];

s[right] = t;

Reverse(s, left + 1, right - 1);

}

char *tenTob(int b,int x)

{

int i=0,k;

static char n[100] = { 0 };

while (x >= b)

{

n[i++] = itos(x%b);

x /= b;

}

n[i] = itos(x);

Reverse(n, 0, i);   //n逆序

return n;

}

int main()

{

//int a, b;

//scanf("%d %d", &a, &b);

char n[100] = { 0 },*a;

gets_s(n, sizeof(n));

puts(tenTob(N,aToten(M,strlen(n),n)));

    return 0;

}


 

0.0分

0 人评分

  评论区

  • «
  • »