牛客编程巅峰赛S1第7场 - 青铜&白银(补题)

数组元素交换

https://ac.nowcoder.com/acm/contest/6630/A

A.数组元素交换

题目描述

牛牛有一个没有重复元素的数组a,他想要将数组内第n大的数字和第m大的数(从大到小排序)交换位置你能帮帮他吗。给定一个数组a,求交换第n大和第m大元素后的数组。

示例1
输入
[1,2],1,2
输出
[2,1]

备注
图片说明

题解

class Solution {
public:
    /**
     * 
     * @param a int整型vector 原始数组a
     * @param n int整型 第n大
     * @param m int整型 第m大
     * @return int整型vector
     */
    vector<int> sovle(vector<int>& a, int n, int m) {
        // write code here
        int index1, index2;
        vector<int> t(a);
        sort(t.begin(), t.end());

        int x = t[t.size()-n];
        int y = t[t.size()-m];
        for(int i = 0; i < a.size(); i++){
            if(a[i] == x) index1 = i;
            if(a[i] == y) index2 = i;
        }
        swap(a[index1], a[index2]);
        return a;
    }
};
全部评论

相关推荐

不愿透露姓名的神秘牛友
06-26 14:50
人力小鱼姐:有后面墨迹那两句的时间问题早回答完了
点赞 评论 收藏
分享
05-29 09:02
门头沟学院 Java
点赞 评论 收藏
分享
昨天 13:37
门头沟学院 Java
点赞 评论 收藏
分享
大飞的诡术妖姬:之前看b站多明海有个说法,日本就业竞争非常低的原因不光是毕业学生少,还有很多人干两年不喜欢职场氛围就辞职躺平,位置也空了很多,论吃苦耐劳还得看咱们
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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