程序员

670. Maximum Swap

2017-09-25  本文已影响0人  namelessEcho

大体的思路是对的 只是在实现的时候不少细节没考虑到,差点没写哭。
首先是StringBuilder的构造体问题 我以为有直接的num构造体就传进去了,结果看了一下目测是被当成capacity了23333怪不得一直显示是空。

问题是寻找一个non-decreasing part直到第一个不满足条件的数,此时整个array被分成了两个部分。一个是non-decreasing part,还有一个是不满足的。我们需要在这个不满足的部分中找到最大的数,考虑到这样的数有多个,那么位置应该是越后面越好,将其交换到交换后仍然可以满足non-decreasing的最高位置上去。

class Solution {
    public int maximumSwap(int num) {
        StringBuilder sb = new StringBuilder();
        sb.append(num);
        for(int i= 0 ;i<sb.length()-1;i++)
        {
            char ch1=sb.charAt(i);
            char ch2=sb.charAt(i+1);
            if(ch1>=ch2)
                continue;
            else
            {
                char max = '0';
                int pos1 = 0 ;
                for(int j=i+1;j<sb.length();j++)
                {
                    char ch = sb.charAt(j);
                    if(ch>=max)//在等于的时候 我们需要向后更新位置 这个位置应该是越后面越好的。
                    {
                        max=ch;
                        pos1=j;
                    }
                }
                int pos2=i;
                //向前寻找 不大于MAX的位置,这个位置是max交换时可以触及的最大位置。
                while(pos2>=0)
                {
                    if(sb.charAt(pos2)<max)
                        pos2--;
                    else
                        break;
                }
                // 第一个大于等于max的位置 可以是-1;表示没有。
                pos2++;
                sb.setCharAt(pos1,sb.charAt(pos2));
                sb.setCharAt(pos2,max);
                break;
            }
        }
        return Integer.parseInt(sb.toString());
    }
}
上一篇下一篇

猜你喜欢

热点阅读