L1-103 整数的持续性 - java

2024-05-06 12:36
文章标签 java 整数 103 l1 持续性

本文主要是介绍L1-103 整数的持续性 - java,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

L1-103 整数的持续性


代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
栈限制
8192 KB


题目描述:

从任一给定的正整数 n n n 出发,将其每一位数字相乘,记得到的乘积为 n 1 n_{1} n1 。以此类推,令 n i + 1 n_{i+1} ni+1 n i n_{i} ni 的各位数字的乘积,直到最后得到一个个位数 n m n_{m} nm ,则 m m m 就称为 n n n 的持续性。例如 679 679 679 的持续性就是 5 5 5,因为我们从 679 679 679 开始,得到 6 × 7 × 9 = 378 6×7×9=378 6×7×9=378,随后得到 3 × 7 × 8 = 168 3×7×8=168 3×7×8=168 1 × 6 × 8 = 48 1×6×8=48 1×6×8=48 4 × 8 = 32 4×8=32 4×8=32,最后得到 3 × 2 = 6 3×2=6 3×2=6,一共用了 5 5 5 步。
本题就请你编写程序,找出任一给定区间内持续性最长的整数。

输入格式:
输入在一行中给出两个正整数 a 和 b( 1 ≤ a ≤ b ≤ 1 0 9 1 \leq a \leq b \leq 10^{9} 1ab109 ( b − a ) < 10 (b − a) < 10 (ba)<10),为给定区间的两个端点。

输出格式:
首先在第一行输出区间 [ a , b ] [a, b] [a,b] 内整数最长的持续性。随后在第二行中输出持续性最长的整数。如果这样的整数不唯一,则按照递增序输出,数字间以 1 1 1 个空格分隔,行首尾不得有多余空格。

输入样例:
500 700
输出样例:
5
679 688 697


找到最长的持续性,并且找到最长持续性的所有数


emmmmmmm

按照题目意思

首先将这个数拆分成各位之积,直到各位之积为个位数。
统计操作的步数。

然后统计最大的步数,输出最大步数的所有数。


import java.io.*;
import java.util.*;public class Main
{
//	将x拆分位各位之积static int fen(int x){int ans = 1;while (x > 0){ans *= x % 10;x /= 10;}return ans;}//	获取x到一个个位需要几步static int get(int x){int cnt = 0;while (x >= 10){x = fen(x);cnt++;}return cnt;}public static void main(String[] args){int a = sc.nextInt();int b = sc.nextInt();int max = 0; // 统计最大值ArrayList<Integer> ar = new ArrayList<Integer>();for (int i = a; i <= b; i++){int j = get(i);
//			如果比最大值大if (j > max){
//				替换持续性max = j;ar = new ArrayList<Integer>();}
//			如果小于最大值,则不添加这个数else if (j < max)continue;
//			添加当前这个数ar.add(i);}out.println(max);for (int i = 0; i < ar.size(); i++){if (i != 0)out.print(" ");out.print(ar.get(i));}out.flush();out.close();}static Scanner sc = new Scanner(System.in);static PrintWriter out = new PrintWriter(System.out);}

ArrayList
ArrayList


如果有说错的 或者 不懂的 尽管提 嘻嘻

一起进步!!!


闪现

这篇关于L1-103 整数的持续性 - java的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/964370

相关文章

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

Spring-DI依赖注入全过程

《Spring-DI依赖注入全过程》SpringDI是核心特性,通过容器管理依赖注入,降低耦合度,实现方式包括组件扫描、构造器/设值/字段注入、自动装配及作用域配置,支持灵活的依赖管理与生命周期控制,... 目录1. 什么是Spring DI?2.Spring如何做的DI3.总结1. 什么是Spring D

spring AMQP代码生成rabbitmq的exchange and queue教程

《springAMQP代码生成rabbitmq的exchangeandqueue教程》使用SpringAMQP代码直接创建RabbitMQexchange和queue,并确保绑定关系自动成立,简... 目录spring AMQP代码生成rabbitmq的exchange and 编程queue执行结果总结s

Java调用Python脚本实现HelloWorld的示例详解

《Java调用Python脚本实现HelloWorld的示例详解》作为程序员,我们经常会遇到需要在Java项目中调用Python脚本的场景,下面我们来看看如何从基础到进阶,一步步实现Java与Pyth... 目录一、环境准备二、基础调用:使用 Runtime.exec()2.1 实现步骤2.2 代码解析三、

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息