59 lines
1.6 KiB
Java
59 lines
1.6 KiB
Java
|
//给定一个非负整数 N,找出小于或等于 N 的最大的整数,同时这个整数需要满足其各个位数上的数字是单调递增。
|
|||
|
//
|
|||
|
// (当且仅当每个相邻位数上的数字 x 和 y 满足 x <= y 时,我们称这个整数是单调递增的。)
|
|||
|
//
|
|||
|
// 示例 1:
|
|||
|
//
|
|||
|
// 输入: N = 10
|
|||
|
//输出: 9
|
|||
|
//
|
|||
|
//
|
|||
|
// 示例 2:
|
|||
|
//
|
|||
|
// 输入: N = 1234
|
|||
|
//输出: 1234
|
|||
|
//
|
|||
|
//
|
|||
|
// 示例 3:
|
|||
|
//
|
|||
|
// 输入: N = 332
|
|||
|
//输出: 299
|
|||
|
//
|
|||
|
//
|
|||
|
// 说明: N 是在 [0, 10^9] 范围内的一个整数。
|
|||
|
// Related Topics 贪心 数学 👍 205 👎 0
|
|||
|
|
|||
|
package leetcode.editor.cn;
|
|||
|
|
|||
|
//738:单调递增的数字
|
|||
|
class MonotoneIncreasingDigits {
|
|||
|
public static void main(String[] args) {
|
|||
|
//测试代码
|
|||
|
Solution solution = new MonotoneIncreasingDigits().new Solution();
|
|||
|
}
|
|||
|
|
|||
|
//力扣代码
|
|||
|
//leetcode submit region begin(Prohibit modification and deletion)
|
|||
|
class Solution {
|
|||
|
public int monotoneIncreasingDigits(int n) {
|
|||
|
char[] arr = (n + "").toCharArray();
|
|||
|
int max = -1, idx = -1;
|
|||
|
for (int i = 0; i < arr.length - 1; i++) {
|
|||
|
if (max < arr[i]) {
|
|||
|
max = arr[i];
|
|||
|
idx = i;
|
|||
|
}
|
|||
|
if (arr[i] > arr[i + 1]) {
|
|||
|
arr[idx] -= 1;
|
|||
|
for (int j = idx + 1; j < arr.length; j++) {
|
|||
|
arr[j] = '9';
|
|||
|
}
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
return Integer.parseInt(new String(arr));
|
|||
|
}
|
|||
|
}
|
|||
|
//leetcode submit region end(Prohibit modification and deletion)
|
|||
|
|
|||
|
}
|