题解 | ##

最大数字交换

http://www.nowcoder.com/practice/ffcd59fbf5814d2e94c0e2f4a679473c

基本思想:越大的数,应当排放在越前面。 当不满足该条件时,与本应放在该位的数值中的最后一个进行交换

public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param num string字符串 
     * @return string字符串
     */
    string maximumSwap(string num) {
        // write code here
        //贪心策略,大小排位越高,排到这个数的越前面
        vector<int>a;
        for(auto c:num){
            a.push_back(c-48);
        }
        int j=-1;
        sort(a.rbegin(),a.rend());//降序排列
        for(int i=0;i<a.size();i++){
            if((num[i]-'0')!=a[i]){
                j=num.find_last_of(char(a[i]+'0'));
            
                swap(num[j],num[i]);
                break;//只交换一次
            }
        }
        return num;
    }
};
全部评论

相关推荐

06-17 00:26
门头沟学院 Java
程序员小白条:建议换下项目,智能 AI 旅游推荐平台:https://github.com/luoye6/vue3_tourism_frontend 智能 AI 校园二手交易平台:https://github.com/luoye6/vue3_trade_frontend GPT 智能图书馆:https://github.com/luoye6/Vue_BookManageSystem 选项目要选自己能掌握的,然后最好能自己拓展的,分布式这种尽量别去写,不然你只能背八股文了,另外实习的话要多投,尤其是学历不利的情况下,多找几段实习,最好公司title大一点的
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务