力扣479(java)-最大回文数乘积(困难)
题目:
给定一个整数 n ,返回 可表示为两个 n 位整数乘积的 最大回文整数 。因为答案可能非常大,所以返回它对 1337 取余 。
示例 1:
输入:n = 2
输出:987
解释:99 x 91 = 9009, 9009 % 1337 = 987
示例 2:
输入: n = 1
输出: 9
提示:
1 <= n <= 8
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/largest-palindrome-product
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路:
数学思维枚举:从n位数构成的最大整数开始从大到小枚举回文数,然后看这个回文数能否由最大整数相乘得到。
1.两个n位数相乘,乘积的位数为 2*n 位,要么为 2*n -1 位;
2.从大到小枚举一个n位数,作为回文数的前半部分,然后根据回文规则,生成回文数的后半部分;
3.最后判断构造的这个回文数,能否整除两个相同的n位数,如果能,则将回文数与1337取余返回即可,不能则返回 -1。
注释:
1.n为1时,最大整数为9, 9*9=81,小于81的回文数有:77,66,55,44,33,22,11,但是这些都不能整除两个相同的1位整数,只能回到回文数为1位的数 9。
2.Math.pow(10, n) - 1 : n位数的最大数为 [ 最小的n+1位数 - 1]
例如:2位数的最大数为 : 1000 - 1 = 99
3位数的最大数为 : 10000 - 1 = 999
4位数的最大数为 : 100000- 1 = 9999
3. (int) Math.pow(10, n) - 1 :为什么要强制转换为 int 类型?
因为math函数返回的是浮点数,而结果需要整数,所以要强制转换为int 类型
4.从大到小枚举回文的前半部分时,构造回文的后半部分
// 99 --> 9999
// 98 --> 9889
// 97 --> 9779
// 96 --> 9669
// ...
// 90 --> 9009
while(t != 0){
num = num * 10 + (t % 10);
t /= 10;
}
5.检查num能否由两个相同的n位整数的乘积构成
//j * j >= num 两个n位整数乘积最小边界为当前的回文num
//j是递减的,如果j * j < num,说明j需要乘一个大于j的数才有可能等于num,但是比j大的数在前面已经除过了
for(long j = max; j * j >= num; j--){
if(num % j == 0){
return (int)(num % 1337);
}
}
6.为什么要将 j 设置成 long型?
210约等于103,int的最大值231约等于109,如果将 j 设置成 int 类型,当n >= 5 时, j * j 就会超出int 类型的最大长度。
代码:
1 class Solution {
2 public int largestPalindrome(int n) {
3 if(n == 1) return 9;
4 //n位数的最大整数
5 int max = (int) Math.pow(10, n) - 1;
6 //从大到小开始枚举
7 for(int i = max; i >= 0; i--){
8 long num = i;
9 long t = i;
10 //构造回文的后半部分
11 while(t != 0){
12 num = num * 10 + (t % 10);
13 t /= 10;
14 }
15 //判断最大回文数能否整除最大整数
16 for(long j = max; j * j >= num; j--){
17 if(num % j == 0){
18 return (int)(num % 1337);
19 }
20 }
21 }
22 return -1;
23 }
24 }
力扣479(java)-最大回文数乘积(困难)的更多相关文章
- Java实现 LeetCode 479 最大回文数乘积
479. 最大回文数乘积 你需要找到由两个 n 位数的乘积组成的最大回文数. 由于结果会很大,你只需返回最大回文数 mod 1337得到的结果. 示例: 输入: 2 输出: 987 解释: 99 x ...
- Java判断回文数算法简单实现
好久没写java的代码了, 今天闲来无事写段java的代码,算是为新的一年磨磨刀,开个头,算法是Java判断回文数算法简单实现,基本思想是利用字符串对应位置比较,如果所有可能位置都满足要求,则输入的是 ...
- Leetcode 479.最大回文数乘积
最大回文数乘积 你需要找到由两个 n 位数的乘积组成的最大回文数. 由于结果会很大,你只需返回最大回文数 mod 1337得到的结果. 示例: 输入: 2 输出: 987 解释: 99 x 91 = ...
- Java 9.回文数
给你一个整数 x ,如果 x 是一个回文整数,返回 true :否则,返回 false .回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数. 例如,121 是回文,而 123 不是. ...
- 479 Largest Palindrome Product 最大回文数乘积
你需要找到由两个 n 位数的乘积组成的最大回文数.由于结果会很大,你只需返回最大回文数 mod 1337得到的结果.示例:输入: 2输出: 987解释: 99 x 91 = 9009, 9009 % ...
- [Swift]LeetCode479. 最大回文数乘积 | Largest Palindrome Product
Find the largest palindrome made from the product of two n-digit numbers. Since the result could be ...
- java基础——回文数判断
/** * 题目描述: * 有这样一类数字,他们顺着看和倒着看是相同的数,例如:121,656,2332等,这样的数字就称为:回文数字.编写一个函数,判断某数字是否是回文数字. * 要求实现方法: * ...
- JAVA求回文数
Manacher算法(马拉车算法)时间复杂度O(n) 用过中心检测法(就是上面说的O(n2) O(n^2)O(n )的算法)的都知道对于奇数回文串和偶数回文串的处理是不同的,奇数回文串有2n+1 2n ...
- 力扣Leetcode 680. 验证回文字符串 Ⅱ
验证回文字符串 Ⅱ 给定一个非空字符串 s,最多删除一个字符.判断是否能成为回文字符串. 示例 1: 输入: "aba" 输出: True 示例 2: 输入: "abca ...
- java解决回文数
递归解决palindrome问题 如果String仅仅只是一个或者0个字符,则它就是palindrome 否则比较字符串第一个和最后一个字符 如果第一个和最后一个字符不同,那么就不是palindrom ...
随机推荐
- settings.json 20201209
李昱版 { "editor.fontSize": 20, "workbench.iconTheme": "material-icon-theme&qu ...
- python元组(tuple)循环遍历实例分析
一 概念: 元组是有序且不可更改的集合.在 Python 中,元组是用圆括号编写的. 二 使用方法: 1 基本创建: thistuple = ("apple", "ba ...
- day06-JavaScript03
JavaScript03 11.DOM 官方文档:https://www.w3school.com.cn/js/js_htmldom.asp 基本介绍: DOM全称是Document Object M ...
- [置顶]
spring巧用继承解决bean的id相同的问题
先感叹一下:最近的项目真的很奇葩!!! 需求是这样的:我们的项目中引用了两个jar包,这两个jar包是其他项目组提供的,不能修改! 奇葩的是:这两个jar中都需要引用方提供一个相同id的bean,而b ...
- FFmpeg命令行之 Unknown encoder ‘libx264‘
在执行下面命令进行摄像头采集时,会报错 Unknown encoder 'libx264' ffmpeg -f dshow -i video="C1E Camera" -vcode ...
- CSS(语义化标签、多媒体标签、新表单元素、属性选择器、结构伪类选择器、伪元素选择器、盒子模型、滤镜、calc函数、过渡)
一.HTML5新特性 概述 HTML5 的新增特性主要是针对于以前的不足,增加了一些新的标签.新的表单和新的表单属性等. 这些新特性都有兼容性问题,基本是 IE9+ 以上版本的浏览器才支持,如果不考虑 ...
- nodejs下载 安装 配置环境
1.下载 下载地址:https://nodejs.org/en/download/ 下载完成后,双击安装包,开始安装,一直点next即可.我把安装路径设置为 D:\Program Files\node ...
- ZYNQ7000系列学习之TF卡读写实验
TF卡读写实验 1.实验原理 开发板上自动带有TF卡外接接口,这里只需调用封装好的IP核即可实现该功能.当然,你还需要一个TF卡(感觉SD卡也可以,反正这两种卡差不多).实验就是调用一个IP核,不涉及 ...
- Linux编写Shell脚本获取指定目录下所有文件并处理
Linux编写Shell脚本获取指定目录下所有文件进行处理并保存到新目录 #!/bin/bash app_name="shell" path="/dir" #原 ...
- 郑州IT微信交流群期待你的加入
我建了一个郑州IT微信交流群,找工作,找项目,人员招聘的都可以加入. 你有一个苹果,我有一个香蕉,合在一起,我们每个人都可以吃到两种水果了.广结人缘,扩大自己的人脉. 可以加我个人微信,拉你进群.