c语言编程:实现数字的翻转

方法一:(易理解的)

#include<stdio.h>
#include<stdlib.h>

int main()
{
	int n;
	scanf("%d",&n);//输入要翻转的数字 
	int result = 0;//保存翻转后的结果
	while(1)//while(true)也可以 
	{
		int i = n%10;//每次都是得到最低位上的数字
		result = result*10+i;
		n = n/10;//递归降位
		if(n == 0)
		{
			break;
		} 
	}
	printf("翻转后的数字是%d\n",result);	
} 

方法二(模块化设计,好像是百度的面试题)

#include<stdio.h>
#include<stdlib.h>

//获取一个整数的位数 
int getWei(int num)
{
	int wei = 0;
	for(int iNum=num;iNum;iNum/=10)//依次去掉最低位 
	{
		printf("%d\n",iNum);//依次打印去掉最低位后的数字 
		wei++;
	}
	return wei;
}

int get10(int n)
{
	int res = 1;
	for(int i=0;i<n;i++)//从0到n进行循环
	{
		res*=10;
	} 
	return res;
}
int main()
{
	int num;
	scanf("%d",&num);
	int wei = getWei(num); 
	printf("%d的位数是%d\n",num,wei);
	int result = 0;//保存最终的翻转结果 
	for(int i=0;i<wei;i++)
	{
		int n;//
		n = num %10;//每次取出的最低位
		num = num / 10;//递归去掉最低位
		result = result+n*get10(wei-1-i);
	}
	printf("翻转后的数字是%d\n",result);
	return 0;
}


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。