您的位置:首页 > 编程语言 > Java开发

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

2017-05-26 21:37 253 查看
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();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: