进制转换练习



  基础练习 十六进制转八进制  
时间限制:1.0s   内存限制:512.0MB
       
问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。

输入格式
  输入的第一行为一个正整数n (1<=n<=10)。
  接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。

输出格式
  输出n行,每行为输入对应的八进制正整数。

   【注意
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。

样例输入
  2
  39
  123ABC

样例输出
  71
  4435274

   提示
  先将十六进制数转换成某进制数,再由某进制数转换成八进制。



AC代码:

#include
#include
#include
#include
using namespace std;
#define inf 0x3f3f3f3f
#define T 1000010
typedef long long ll;

char s[T];
int n,c,num[T],n8[T],len;

int fun(char str)
{
	if(str>='A'&&str<='F')
	return str-'A'+10;
	return str-'0';
}

void _2()
{
	c = 0;
	for(int i=len-1;i>=0;--i){
		int tmp = fun(s[i]);
		for(int j=0;j<4;j++){
			num[c++] = ((tmp >>j)&1);
		}
	}	
		while(!num[c-1])
		{
			c--;
		}
}

void _8()
{
	int i,c8=0;
	for(i=0;i+3<=c;i+=3){
		n8[c8++]=num[i]*1+num[i+1]*2+num[i+2]*4;
	}
	if(i=0;--i){
		printf("%d",n8[i]);
	}
	printf("\n");
}

int main()
{
	//freopen("input.txt","r",stdin);
	int m,i,j,k;
	scanf("%d",&n);
	while(n--)
	{
		scanf("%s",s);
		len = strlen(s);
		_2();
		_8();
	}
	return 0;
} 


  基础练习 十六进制转十进制  
时间限制:1.0s   内存限制:512.0MB
       
问题描述
  从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
  注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535

AC代码:

#include
#include
#include
#include
#include
using namespace std;
#define inf 0x3f3f3f3f
#define T 1000010
typedef long long ll;

char s[T];
int n,c,num[T],len;

int fun(char str)
{
	if(str>='A'&&str<='F')
	return str-'A'+10;
	return str-'0';
}

void _2()
{
	c = 0;
	for(int i=len-1;i>=0;--i){
		int tmp = fun(s[i]);
		for(int j=0;j<4;j++){
			num[c++] = ((tmp >>j)&1);
		}
	}	
		while(!num[c-1])
		{
			c--;
		}
}

void _10()
{
	ll sum = 0;
	for(int i=c-1;i>=0;--i){
		sum =sum*2 + num[i];
	}
	printf("%lld\n",sum);
}

int main()
{
	//freopen("input.txt","r",stdin);
	int m,i,j,k;
	while(~scanf("%s",s))
	{
		len = strlen(s);
		_2();
		_10();
	}
	return 0;
} 


  基础练习 十进制转十六进制  
时间限制:1.0s   内存限制:512.0MB
       
问题描述
  十六进制数是在程序设计时经常要使用到的一种整数的表示方式。它有0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F共16个符号,分别表示十进制数的0至15。十六进制的计数方法是满16进1,所以十进制数16在十六进制中是10,而十进制的17在十六进制中是11,以此类推,十进制的30在十六进制中是1E。
  给出一个非负整数,将它表示成十六进制的形式。
输入格式
  输入包含一个非负整数a,表示要转换的数。0<=a<=2147483647
输出格式
  输出这个整数的16进制表示
样例输入
30
样例输出
1E


AC代码:

#include
#include
#include
#include
#include
using namespace std;
#define inf 0x3f3f3f3f
#define T 1000010
typedef long long ll;

char s[T];
int n,c,num[T],len;

char fun(int x)
{
	if(x>=10&&x<=15)
	return 'A'+x-10;
	return x+'0';
}

void _2()
{
	c = 0;
	while(n>0)
	{
		num[c++] = n&1;
		n >>=1;
	}
}

void _16()
{
	int c16 = 0,i,tmp,t;
	for(i=0;i+4<=c;i+=4){
		s[c16++] = fun(num[i]*1+num[i+1]*2+num[i+2]*4+num[i+3]*8);
	}
	if(i=0;--i){
		printf("%c",s[i]);
	}
	printf("\n");
}

int main()
{
	//freopen("input.txt","r",stdin);
	int m,i,j,k;
	while(~scanf("%d",&n))
	{
		if(n==0)printf("0\n");
		else{
			_2();
			_16();
		}
	}
	return 0;
} 



  基础练习 十六进制转八进制  
时间限制:1.0s   内存限制:512.0MB
       
问题描述
  给定n个十六进制正整数,输出它们对应的八进制数。

输入格式
  输入的第一行为一个正整数n (1<=n<=10)。
  接下来n行,每行一个由0~9、大写字母A~F组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。

输出格式
  输出n行,每行为输入对应的八进制正整数。

   【注意
  输入的十六进制数不会有前导0,比如012A。
  输出的八进制数也不能有前导0。

样例输入
  2
  39
  123ABC

样例输出
  71
  4435274

   提示
  先将十六进制数转换成某进制数,再由某进制数转换成八进制。

你可能感兴趣的:(水题)