给定一个非负整数,你至多可以交换一次数字中的任意两位。返回你能得到的最大值。
示例 1 :
输入: 2736
输出: 7236
解释: 交换数字2和数字7。
示例 2 :
输入: 9973
输出: 9973
解释: 不需要交换。
注意:
给定数字的范围是 [0, 108]
int maximumSwap(int num) {string charArray = to_string(num);int max = num;int len = charArray.size();for (int i = 0; i < len; i++){for (int j = i+1; j < len; j++){swap(charArray[i], charArray[j]);max = max > stoi(charArray) ? max : stoi(charArray);//stoi()函数将字符串转换为整型或其他进制swap(charArray[i], charArray[j]);//由于需要比较最大的值,所以需要交换回去,继续比较}}return max;
}