数字逆序输出

数字逆序输出

今天在做算法题时碰到数字逆序输出的题目,在网上看到一种解法,挺巧妙的,记录一下。
方法一

		int result=0;
		int x=123;
		while(x!=0){
			result *= 10;//行1
			result += x % 10;//行2
			x /= 10;//行3
		}

简单解释一下:

第一个循环开始:行1在第一步并没有用,仅接着行2将加上了原数的个位数,最后行3让原数除以10,去除个位,此时第一个循环结束
第二个循环开始:行1让加上个位数的result乘10,再加上除以10后的原数的个位数,以此循环。。。


方法二

public void function(int n){
	System.out.print(n%10);
		if (n > 10){
			function(n/10);
		}
}

此方法使用了递归,比方法一更简练

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值