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

来源:互联网 发布:程序员所说的接口 编辑:程序博客网 时间:2024/06/08 10:54
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;}//输入只有一个数字,不需要相乘就达到输出目的,因此相乘次数为0if(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之间的数字,而非字符ASCIIif(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();}}

原创粉丝点击