C语言 数字进制间的转换

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
void D_B(int);
void D_X(int);
void B_D(int);
void B_X(int);
void X_B(char r[],int k);
void X_D(char r[],int k);
void main()
{
	int i,j,k=0;
	int q;
	char r[10];
	do
	{ 
		q=0;
		printf("\n请选择需要被转换的进制:\n0、退出\n1、二进制\n2、十进制\n3、十六进制\n");
		scanf("%d",&i);
		switch (i)
		{
		case 1: 
			printf("\n请选择转换后的进制:\n0、退出\n1、二进制\n2、十进制\n3、十六进制\n");
			scanf("%d",&j);
			switch(j)
			{
			case 1: printf("\n同进制之间不用转化!\n");
				q=1;       
				break;     
			case 2: printf("\n请输入您想要转化的数:");
				scanf("%d",&k);
				B_D(k);
				q=1;
				break;
			case 3: printf("\n请输入您想要转化的数:");
				scanf("%d",&k);
				B_X(k);
				q=1;
				break;
			case 0: 
				q=1;
				break;
			}
			break;  
			case 2: 
				printf("\n请选择转换后的进制:\n0、退出\n1、二进制\n2、十进制\n3、十六进制\n");
				scanf("%d",&j);
				switch(j)
				{
				case 2: printf("\n同进制之间不用转化!\n");
					q=1;      
					break;
				case 1: printf("\n请输入您想要转化的数:");
					scanf("%d",&k);
					D_B(k);
					q=1;
					break;
				case 3: printf("\n请输入您想要转化的数:");
					scanf("%d",&k);
					D_X(k);
					q=1;
					break;
				case 0: 
					q=1; 
					break;     
				} 
				break;
				case 3: 
					printf("\n请选择转换后的进制:\n0、退出\n1、二进制\n2、十进制\n3、十六进制\n");
					scanf("%d",&j);
					switch(j)
					{
					case 3: 
						printf("\n同进制之间不用转化!\n");
						q=1;
						break;
					case 1: printf("\n请输入您想要转化的数:");
						fflush(stdin);
						gets(r);
						for(k=0;;k++)
						{
							if(r[k]=='\0')
								break;
						}       
						X_B(r,k);
						q=1;
						break;    
					case 2: 
						printf("\n请输入您想要转化的数:");    
						fflush(stdin);
						gets(r);
						for(k=0;;k++)
						{
							if(r[k]=='\0')
								break;
						}
						X_D(r,k);
						q=1;
						break;
					case 0: 
						q=1;
						break;        
					}
					break;
					case 0: 
						printf("\n谢谢使用!\n");
		}
	}while(q==1);
}

void B_D(int a)
{
	int i,s=0;
	int result=0;
	for(i=1;a!=0;i*=2)
	{
		if(a%10>1)
		{ 
			s=1;
			break;
		}
		else
		{
			result+=(a%10)*i;
			a=a/10;
		}
	}
	if(s==1)
		printf("您的输入有误!请重新输入\n");
	else
		printf("\n转换后的数为:%d\n",result);
}
void B_X(int a)
{
	int i,j,k,s=0;
	char p[30];
	int result=0;
	for(i=1;a!=0;i*=2)
	{
		if(a%10>1)
		{ 
			s=1;
			break;
		}
		else
		{
			result+=(a%10)*i;
			a=a/10;
		}
	}
	for(j=0;result!=0;j++)
	{
		p[j]=result%16;
		result=result/16;
		if (p[j]>=10)
		{
			switch(p[j])
			{
			case 10: p[j]='A';
				break;
			case 11:  p[j]='B';
				break;
			case 12: p[j]='C';
				break;
			case 13:  p[j]='D';
				break;
			case 14:  p[j]='E';
				break;
			case 15:  p[j]='F';
				break;
			}
		}
		else 
			p[j]+=48;
	}
	if(s==1)
		printf("您的输入有误!请重新输入\n");
	else 
	{
		printf("\n转换后的数为:");
		for(k=j-1;k>=0;k--)
		{
			printf("%c",p[k]);
		}
		printf("\n");
	}
}

void X_D(char a[],int k)
{
	int i,j,s=0;
	int result=0;
	int b[50];
	for(i=0;i<k;i++)
	{
		if(a[i]<='9'&&a[i]>='1')
		{ 
			b[i]=a[i]-48;     
		}
		else
		{
			switch(a[i])
			{
			case 'A': 
				b[i]=10;
				break;
			case 'B': 
				b[i]=11;
				break;
			case 'C':  
				b[i]=12;
				break;
			case 'D': 
				b[i]=13;
				break;
			case 'E': 
				b[i]=14;
				break;
			case 'F':  
				b[i]=15;
				break;
			case 'a': 
				b[i]=10;
				break;
			case 'b': 
				b[i]=11;
				break;
			case 'c':   
				b[i]=12;
				break;
			case 'd': 
				b[i]=13;
				break;
			case 'e':   
				b[i]=14;
				break;
			case 'f':  
				b[i]=15;
				break;
			default: s=1;     
			}
		}
	}
	for(i=1,j=k-1;j>=0;j--,i*=16)
	{
		result+=b[j]*i;
	}
	if(s==1)
		printf("您的输入有误!请重新输入\n");
	else 
	{
		printf("\n转换后的数为:%d",result);
	}
}

void X_B(char a[],int k)
{
	int i,j,s=0;
	int result=0;
	int b[50];
	int p[30];
	for(i=0;i<k;i++)
	{
		if(a[i]<='9'&&a[i]>='1')
			b[i]=a[i]-48;
		else
		{
			switch(a[i])
			{
			case 'A': 
				b[i]=10;
				break;
			case 'B': 
				b[i]=11;
				break;
			case 'C':  
				b[i]=12;
				break;
			case 'D':
				b[i]=13;
				break;
			case 'E': 
				b[i]=14;
				break;
			case 'F':  
				b[i]=15;
				break;
			case 'a': 
				b[i]=10;
				break;
			case 'b':
				b[i]=11;
				break;
			case 'c':  
				b[i]=12;
				break;
			case 'd':  
				b[i]=13;
				break;
			case 'e':   
				b[i]=14;
				break;
			case 'f':   
				b[i]=15;
				break;
			default: 
				s=1;
			}
		}
	}
	for(j=k-1,i=1;j>=0;j--,i*=16)
	{
		result+=b[j]*i;
	}
	for(j=0;result!=0;j++)
	{
		p[j]=result%2;
		result=result/2;
	}
	if(s==1)
		printf("您的输入有误!请重新输入\n");
	else 
	{
		printf("\n转换后的数为:");
		for(k=j-1;k>=0;k--)
		{
			printf("%d",p[k]);
		}
		printf("\n");
	}
}

void D_B(int a)
{
	int j,k;
	int p[30];
	for(j=0;a!=0;j++)
	{
		p[j]=a%2;
		a=a/2;
	}
	printf("\n转换后的数为:");
	for(k=j-1;k>=0;k--)
	{
		printf("%d",p[k]);
	}
	printf("\n");
}

void D_X(int a)
{
	int j,k;
	int p[30];
	for(j=0;a!=0;j++)
	{
		p[j]=a%16;
		a=a/16;
		
		if(p[j]<10)
			p[j]+=48;
		else
		{
			switch(p[j])
			{
			case 10: 
				p[j]='A';
				break;
			case 11: 
				p[j]='B';
				break;
			case 12:    
				p[j]='C';
				break;
			case 13: 
				p[j]='D';
				break;
			case 14:    
				p[j]='E';
				break;
			case 15:   
				p[j]='F';
				break;
			}
		}
	}
	printf("\n转换后的数为:");
	for(k=j-1;k>=0;k--)
	{
		printf("%c",p[k]);
	}
	printf("\n");
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值