POJ1546(进制转换)

简介: #include #include #include int c[10];//6个F位2亿多,9位即可 char arr[16]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'}; int convert...
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int c[10];//6个F位2亿多,9位即可
char arr[16]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
int convert_ten(int a,char num[])
{
	int i,ans=0;
	int len=strlen(num);
	if(len>7)
	{
		printf("  ERROR\n");
		exit(0);
	}
	for(i=0;i<len;i++)
	{
		ans*=a;
		if(num[i]>='0'&&num[i]<='9')
			ans+=num[i]-'0';
		else
			ans+=num[i]-'A'+10;
	}
	return ans;
}
int convert_b(int temp,int b)
{
	int j=0,i;
    int temp0;
    memset(c,0,sizeof(c));
	if(0==temp)//不加该语句,输入0,无结果
	{
		c[0]=0;
		return 1;
	}
	else
	{
		while(temp)
		{
			c[j++]=temp%b;
			temp/=b;
		}
		/*
		没必要 
		for(i=0;i<j/2;i++)
		{
			temp0=c[i];
			c[i]=c[j-i-1];
			c[j-i-1]=temp0;
		}
		*/ 
	}
	return j;
}
int main()
{
	char num[8];
	int a,b;
    int temp,len,k;
	while(~scanf("%s %d %d",num,&a,&b))
	{
		temp=convert_ten(a,num);
		len=convert_b(temp,b);
		if(len>7)
		{
			printf("  ERROR\n");
			continue;
		}
		else
		{
			for(k=0;k<7-len;k++)
				putchar(' ');
			for(k=len-1;k>=0;k--)
					putchar(arr[c[k]]);
		}
		putchar('\n');
		//fflush(stdin);
		memset(num,0,sizeof(num));
	}
	return 0;
}
  

 输出的时候还可以

//十六进制按大写输出
char chuli(int x)
{
	x += 48;
	if(x>57)
		x += 7;
	return (char)x;
}

 

目录
相关文章
|
12月前
|
Java C++
poj 1503 高精度加法
把输入的数加起来,输入0表示结束。 先看我Java代码,用BigINteger类很多东西都不需要考虑,比如前导0什么的,很方便。不过java效率低点,平均用时600ms,C/C++可以0ms过。
38 1
【LeetCode-每日一题】-67. 二进制求和
【LeetCode-每日一题】-67. 二进制求和
|
测试技术
华为机试HJ5:进制转换
华为机试HJ5:进制转换
101 0
|
人工智能
每日一题1055:进制转换
题目描述: 编程,输入一个10进制正整数,然后输出它所对应的八进制数。 样例输入:
102 0
AcWing 756. 蛇形矩阵
AcWing 756. 蛇形矩阵
68 0
AcWing 756. 蛇形矩阵
|
存储 机器学习/深度学习 算法
[解题报告](第19讲) 进制转换(一) - 入门(2)
[解题报告](第19讲) 进制转换(一) - 入门
[解题报告](第19讲) 进制转换(一) - 入门(2)
|
存储 算法
[解题报告](第19讲) 进制转换(一) - 入门(1)
[解题报告](第19讲) 进制转换(一) - 入门
[解题报告](第19讲) 进制转换(一) - 入门(1)