#LQC20240305. 比n小的最大数

比n小的最大数

编程实现

给定一个正整数nn,请将n中的每位数字重新排列并组成一个新数,要求新数的值要小于nn,请找出所有符合要求的新数中最大的那个正整数,如果不存在这样的正整数,则输出 1-1

例1:n=312312n = 312,312中每位上的数字依次是3123、1、2,重新排列组成的新数有321231213132123321、231、213、132、123,新数中小于312312的有231213132123231、213、132、123,其中符合要求的最大正整数是231231;

例 2:n=123n = 123123123中每位上的数字依次是1231、2、3,重新排列组成的新数有312321231213132312、321、231、213、132,新数中不存在小于123123的正整数,故输出1-1

输入描述

输入一个正整数 n(1n263)n (1 \le n \le 2 ^ {63} ) ,整数之间以一个空格隔开

输出描述

输出一个正整数,表示符合要求的最大正整数

样例

输入样例 #1

312

输出样例 #1

231