【牛客编程巅峰赛S1第7场】数组元素交换

数组元素交换

https://ac.nowcoder.com/acm/problem/208140

题目

给定一个没有重复元素的数组 a,将数组内第 n 大的数字和第 m 大的数(从大到小排序)交换位置后返回数组。

解题思路

因为题目已说明数组 a 没有重复元素,所以可以使用 map 数据结构记录每个元素的下标,同时将数组中的元素按照从小到大排序。
遍历 mp 中的元素,使用 k 表示它是第 k 大的元素,如果 k 与 n 或 m 相等,记录它们的下标,最后交换元素,返回数组 a。

C++代码

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
        map<int,int> mp;
        for(int i=0; i<a.size(); ++i)
            mp[a[i]] = i;
        int k = a.size();
        int ni=0, mi=0;
        for(auto it=mp.begin(); it!=mp.end(); ++it){
            if(k==n)
                ni = it->second;
            if(k==m)
                mi = it->second;
            --k;
        }
        swap(a[ni], a[mi]);
        return a;
    }
};
全部评论

相关推荐

醉蟀:你不干有的是人干
点赞 评论 收藏
分享
每晚夜里独自颤抖:你cet6就cet6,cet4就cet4,你写个cet证书等是什么意思。专业技能快赶上项目行数,你做的这2个项目哪里能提现你有这么多技能呢
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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