牛客笔试-变换次数

题目地址

题目

牛牛想对一个数做若干次变换,直到这个数只剩下一位数字。

变换的规则是:将这个数变成 所有位数上的数字的乘积。比如285经过一次变换后转化成28 5=80.

问题是,要做多少次变换,使得这个数变成个位数。

输入描述:

输入一个正整数。小于等于2,000,000,000。

输出描述:

输出一个整数,表示变换次数。

示例1

输入

285

输出

2

题解

直接模拟题目中的运算即可,开启一个循环,不断计算当前数字的每个位数的和,将最终结果赋值回num

循环结束的标志是num为个位数

python

bash 复制代码
num = int(input("Enter a number: "))
count = 0

while num > 9:
    a = num % 10  
    while num // 10 > 0:
        num //= 10  
        a *= num % 10  
    count += 1
    num = a

print(count)

Java

bash 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int num = scanner.nextInt();
        int count = 0;

        while (num > 9) {
            int a = num % 10; 
            while (num / 10 > 0) {
                num /= 10;
                a *= num % 10; 
            }
            count++;
            num = a;
        }
        System.out.println(count);
        scanner.close();
    }
}
相关推荐
B站_计算机毕业设计之家5 分钟前
深度血虚:Django水果检测识别系统 CNN卷积神经网络算法 python语言 计算机 大数据✅
python·深度学习·计算机视觉·信息可视化·分类·cnn·django
Q_Q5110082857 分钟前
python+django/flask的校园活动中心场地预约系统
spring boot·python·django·flask·node.js·php
2301_801252229 分钟前
Tomcat的基本使用作用
java·tomcat
lkbhua莱克瓦2410 分钟前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
小白程序员成长日记11 分钟前
2025.11.07 力扣每日一题
数据结构·算法·leetcode
·白小白13 分钟前
力扣(LeetCode) ——209. 长度最小的子数组(C++)
c++·算法·leetcode
工会主席-阿冰13 分钟前
数据索引是无序时,直接用这个数据去画图的话,显示的图是错误的
开发语言·python·数据挖掘
小猪咪piggy15 分钟前
【算法】day16 动态规划
算法·动态规划
ohnoooo916 分钟前
251106 算法
数据结构·c++·算法
麦麦鸡腿堡18 分钟前
Java_TreeSet与TreeMap源码解读
java·开发语言