关注
#include <iostream>
#include<string>
#include <list>
#include <vector>
#include <map>
#include <set>
#include <unordered_map>
#include <unordered_set>
#include <algorithm>
#include <iomanip>
using namespace std;
// 插入排序
template<class randomaccessiterator, class T>
void _unguarded_insert_aux(randomaccessiterator last, T value) {
randomaccessiterator next = last - 1;
while (*next >value) {
*last = *next;
last = next;
--next;
}
*last = value;
}
template<class randomaccessiterator>
void _insert_aux(randomaccessiterator first, randomaccessiterator last) {
typedef typename std::iterator_traits<randomaccessiterator>::value_type T;
T value = *last;
if (*first > value) {
std::copy_backward(first, last, last + 1);
*first = value;
}
else _unguarded_insert_aux(last, value);
}
template<class randomaccessiterator>
void _insert_sort(randomaccessiterator first, randomaccessiterator last) {
randomaccessiterator tmp = first + 1;
while (tmp != last) {
_insert_aux(first, tmp);
++tmp;
}
}
//求 数组首、中、尾元素的中位数,防止分割恶化
template<class T>
inline const T& _median(const T&a, const T&b, const T&c) {
if (a < b) {
if (b < c) return b;
else if (a<c) return c;
else return a;
}
else {
if (c > a) return a;
else if (c>b)return c;
else return b;
}
}
//做分割处理
template<class randomaccessiterator, class T>
randomaccessiterator t_pivot_partition(randomaccessiterator first, randomaccessiterator last, T pivot) {
while (true) {
while (*first < pivot) ++first;
--last;
while (*last > pivot) --last;
if (!(first < last)) return first;
std::swap(*first, *last);
++first;
}
}
//求区间第k小的元素
template <class RandomAccessIterator>
void my_nth_element(RandomAccessIterator first, RandomAccessIterator nth, RandomAccessIterator last) {
while (last - first >= 3) {
RandomAccessIterator tmp = t_pivot_partition(first, last, _median(*first, *(last - 1), *(first + (last - first) / 2)));
if (tmp <= nth)
first = tmp;
else last = tmp;
}
_insert_sort(first, last);
}
//包装函数
int KthArray(vector<int>& nums,int k) {
my_nth_element(nums.begin(),nums.begin()+k,nums.end());
return *(nums.begin() + k);
}
int main() {
int n;
vector<int> vec;
while (cin>>n) {
vec.push_back(n);
}
int k = vec[vec.size() - 1];
vec.pop_back();
cout << KthArray(vec, vec.size()-k)<< endl;
return 0;
}
查看原帖
点赞 评论
相关推荐
07-09 13:51
门头沟学院 Java 还处在暑期实习上岸后的摆烂状态实习:杂活多,产出少,文档也没偷学多少八股:忘的差不多了项目:有实习就不会问玩具项目了吧力扣:我可以说我连hot 100都没刷完吗国企:从零开始准备论文:没着落
回收旧报纸:世另我,只是我比你更烂一些,没找到实习,你起码还有实习的,秋招猛猛冲,加油
点赞 评论 收藏
分享
07-01 01:25
辽宁科技大学 Java 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 技术岗笔试题求解 #
77553次浏览 1005人参与
# 拼多多求职进展汇总 #
642282次浏览 4983人参与
# 工作一周年分享 #
30695次浏览 179人参与
# 如果公司给你放一天假,你会怎么度过? #
16231次浏览 122人参与
# 作业帮求职进展汇总 #
55740次浏览 370人参与
# 华子oc时间线 #
1236368次浏览 6473人参与
# OPPO求职进展汇总 #
662142次浏览 5032人参与
# 总结:哪家公司面试体验感最差 #
60451次浏览 273人参与
# 职场上哪些事情令人讨厌 #
18711次浏览 91人参与
# 三一重工求职进展汇总 #
14299次浏览 65人参与
# 去年你投递实习了吗? #
21972次浏览 329人参与
# 这些公司卡简历很严格 #
41275次浏览 204人参与
# 扒一扒那些奇葩实习经历 #
66290次浏览 913人参与
# 经纬恒润求职进展汇总 #
121654次浏览 1032人参与
# 提前批过来人的忠告 #
113838次浏览 1194人参与
# 说说你知道的学历厂 #
58216次浏览 351人参与
# 秋招最大的收获是什么? #
36867次浏览 311人参与
# 找工作时的取与舍 #
80006次浏览 566人参与
# 你认为小厂实习有用吗? #
29218次浏览 341人参与
# 哪一瞬间觉得自己长大了 #
13845次浏览 327人参与