变换次数-Java-牛客模拟三

package 模拟三;

import java.util.Scanner;

/**
 * 题目大意:牛牛想对一个数做若干次变换,直到这个数只剩下一位数字。 变换的规则是:
 * 将这个数变成所有位数上的数字的乘积。比如285经过一次变换后转化成2*8*5=80. 
 * 问题是,要做多少次变换,使得这个数变成个位数。 
 * 输入描述:输入一个整数。小于等于2,000,000,000。
 * 
 * 输出描述: 输出一个整数,表示变换次数。
 * 输入例子: 285
 * 输出例子: 2
 * @author 崔洪振367
 * @version 创建时间:2017年5月22日 下午8:45:12
 * 解题思路:逐位遍历数字,遇到0时直接输出。只有不是0才不断循环,直到最后剩余1位时输出。
 */
public class Q2017_1变换次数 {

	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		while(scanner.hasNext()){
			String string = scanner.next();
			if(string.length() == 0 || string == null){
				return;
			}
			
			//输入只有一个数字,不需要相乘就达到输出目的,因此相乘次数为0
			if(string.length() == 1){
				System.out.println(0);
				return;
			}
			int count = 0;//统计循环的次数
			while(true){
				count++;
				int len = string.length();
				long sum = 1;
				for(int i=0; i<len; i++){
					int t = string.charAt(i)-'0';//将字符转为0-9之间的数字,而非字符ASCII
					if(t == 0){
						System.out.println(count);
						return;
					}else {
						sum *= t;
					}
				}
				if(sum < 10){//判断sum是否为一个数字,是的话输出count,并结束循环。
					System.out.println(count);
					return;
				}
				string = new String(sum+"");
			}
		}
		scanner.close();
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值