给你一个仅由数字 6 和 9 组成的正整数 num。
你最多只能翻转一位数字,将 6 变成 9,或者把 9 变成 6 。
请返回你可以得到的最大数字。
示例 1:
输入:num = 9669
输出:9969
解释:
改变第一位数字可以得到 6669 。
改变第二位数字可以得到 9969 。
改变第三位数字可以得到 9699 。
改变第四位数字可以得到 9666 。
其中最大的数字是 9969 。
示例 2:
输入:num = 9996
输出:9999
解释:将最后一位从 6 变到 9,其结果 9999 是最大的数。
示例 3:
输入:num = 9999
输出:9999
解释:无需改变就已经是最大的数字了。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-69-number
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
int maximum69Number (int num){
if(num/1000 == 6)
return num+3000;
else if((num/100)%10 == 6)
return num+300;
else if((num/10)%10 == 6)
return num+30;
else if(num%10 == 6)
return num+3;
else
return num;
}
思路白给,从左到右找到第一个6,把其转换成9,如果没有6,那就返回原数。
如果思维扩散下,比如如果不是四位数,而是五位甚至更多位,那么就把原数拆分开来放入一个数组,同样找到从左到右第一个6的位置,把它变成9,然后把数组组合成数字。至于组合方式可以是把数组每一位乘以10的次方然后相加变成四位整数。
如果不想用数组,那么可以用一个标志位来记录从左到右第一个6的位置:
#include <Math.h>
int maximum69Number (int num){
int count = 0, th = 0; // count 记录除了多少次,th记录最大的6在第几位
int re = num;
while(re){
count++;
if(re%10==6)
th = count;
re /= 10;
}
return num+3*pow(10,th-1);
}