有啥好的排序算法解这个题嘛?

一组数按个位数从大到小排列,个位数相同的按实际大小排列,有没有啥好的算法来解?
我只会笨办法= =!
#笔试题目#
全部评论
写个cmp比较器,用stl的sort
点赞 回复 分享
发布于 2019-09-08 06:33
数组排序的常规做法就是定义个比较函数然后传进排序函数: #include <algorithm> #include <iostream> #include <vector> using namespace std; int main(int argc, char* argv[]) { vector<int> nums = {2, 3, 5, 7, 11, 13, 15, 17}; sort(nums.begin(), nums.end(), [](int x, int y) { int units_x = x % 10; int units_y = y % 10; if (units_x == units_y) return x < y; return units_x < units_y; }); for (int x : nums) cout << x << " "; cout << endl; return 0; }不过这里个位数的值只有0-9一共10种,所以像楼上一样分到10个vector中排序,然后依次汇总应该才是题目想要的做法,毕竟给定的数组是有序的,这个条件在之前的代码里没利用: #include <assert.h> #include <algorithm> #include <array> #include <iostream> #include <vector> using namespace std; int main(int argc, char* argv[]) { // nums为有序数组 vector<int> nums = {2, 3, 5, 7, 11, 13, 15, 17}; array<vector<int>, 10> buckets; // TODO: use array<forward_list, 10> may be better? for (int x : nums) buckets[x % 10].emplace_back(x); size_t index = 0; for (const auto& v : buckets) { for (int x : v) { assert(index < nums.size()); nums[index++] = x; } } for (int x : nums) cout << x << " "; cout << endl; return 0; }
点赞 回复 分享
发布于 2019-09-08 02:42
个位数相同的按实际大小排列啥意思,降序还是升序
点赞 回复 分享
发布于 2019-09-08 01:51
归并可以么?
点赞 回复 分享
发布于 2019-09-10 12:31
快排,自定义一下比较方法就行了
点赞 回复 分享
发布于 2019-09-10 12:30
桶排
点赞 回复 分享
发布于 2019-09-08 13:45
笨办法,基数排序里的一次分发和收集😂
点赞 回复 分享
发布于 2019-09-08 09:00
先遍历一遍最多分成十个部分。然后用sort给每个部分排序。最后在把十个部分输出
点赞 回复 分享
发布于 2019-09-08 08:09
这不是定义个比较函数就可以调用std sort了吗,4行?
点赞 回复 分享
发布于 2019-09-08 08:06
可以对cmp函数进行重写然后调用sort就行了,代码如下 bool cmp(long long a, long long b) { if (a % 10 != b % 10) return a % 10 < b % 10; return a < b; } void Sort_out(vector<long long>& val) { sort(val.begin(), val.end(), cmp); vector<long long>::iterator it = val.begin(); while (it != val.end()) { cout << *it << endl; it++; } }
点赞 回复 分享
发布于 2019-09-08 02:33
题目加完整代码: #include <iostream> #include <vector> using namespace std; //每行输入一个数字 0 < N < 10 0000, 输出0 - N之间的所有质数,并且质数按个位数从大到小排列,个位数相同的按实际大小排列 vector<long long> vec;//用来存放所有的质数 void getPrime(long long val) { if (val < 2) return; if (val == 2) { vec.push_back(2); return; } for (int i = 2; i < val; i++) { int flag = true; for (int j = 2; j <= sqrt(i); j++) { if (i % j == 0) { flag = false; break; } } if (flag) { vec.push_back(i); flag = true; } } } void getPrime_2(long long val, long long temp) { for (int i = temp; i < val; i++) { int flag = true; for (int j = 2; j <= sqrt(i); j++) { if (i % j == 0) { flag = false; break; } } if (flag) { vec.push_back(i); flag = true; } } } void Sort_out(vector<long long>& val) { vector<vector<long long> > tmp = { {},{},{},{},{},{},{},{},{} }; vector<long long>::iterator it = val.begin(); while(it != val.end()) { switch ((*it % 10)) { case 1: tmp[0].push_back(*it); break; case 2: tmp[1].push_back(*it); break; case 3: tmp[2].push_back(*it); break; case 4: tmp[3].push_back(*it); break; case 5: tmp[4].push_back(*it); break; case 6: tmp[5].push_back(*it); break; case 7: tmp[6].push_back(*it); break; case 8: tmp[7].push_back(*it); break; case 9: tmp[8].push_back(*it); break; } it++; } vector<long long>::iterator head; for (int i = 0; i < 9; i++) { head = tmp[i].begin(); while (head != tmp[i].end()) { cout << *head << endl; head++; } } } int main() { long long val; long long temp = 0;//存放上一个N cin >> val; getPrime(val); temp = val; Sort_out(vec); while (cin >> val) { if (val > temp)//如果新输入的N大于上一个则需要再次寻找更多的质数。 { getPrime_2(val, temp); temp = val; } else//否则删除多于的质数 { while (vec.back() > val) vec.pop_back(); temp = val; } Sort_out(vec); } return 0; }
点赞 回复 分享
发布于 2019-09-08 02:22
取个位数,分别装到size==10的vector<vector<int>>里去,再对这10个vector<int>每个都进行排序
点赞 回复 分享
发布于 2019-09-08 02:09
有dalao有想法嘛?我用的是C++
点赞 回复 分享
发布于 2019-09-08 01:59

相关推荐

不愿透露姓名的神秘牛友
07-09 12:30
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-09 11:15
点赞 评论 收藏
分享
05-23 19:02
吉林大学 Java
点赞 评论 收藏
分享
06-13 10:15
门头沟学院 Java
想去夏威夷的大西瓜在...:我也是27届,但是我现在研一下了啥项目都没有呀咋办,哎,简历不知道咋写
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-11 12:31
以前小时候我最痛恨出轨、偷情的人,无论男女,为什么会出轨?现在我成了自己最讨厌的人,没想到分享的东西在牛客会被这么多人看,大家的评价都很中肯,我也认同,想过一一回复,但我还是收声了,我想我应该说说这件事,这件事一直压在我心里,是个很大的心结,上面说了人为什么出轨,我大概能明白了。我们大一下半年开始恋爱,开始恋爱,我给出了我铭记3年的承诺,我对她好一辈子,我永远不会背叛,我责任心太重,我觉得跟了我,我就要照顾她一辈子,我们在一起3年我都没有碰过她,她说往东我就往东,她说什么我做什么,她要我干什么,我就干什么!在学校很美好,中途也出过一些小插曲,比如男闺蜜、男闺蜜2号等等等。但我都强迫她改掉了,我...
牛客刘北:两个缺爱的人是没有办法好好在一起的,但世界上哪有什么是非对错?你后悔你们在一起了,但是刚刚在一起的美好也是真的呀,因为其他人的出现,你开始想要了最开始的自己,你的确对不起自己,21岁的你望高物远,你完全可以不谈恋爱,去过你想要的生活,你向往自由,在一起之后,你要想的不是一个人,而是两个人,你不是变心了,就像你说的,你受够了,你不想包容了,冷静几天是你最优的选择,爱人先爱己。
社会教会你的第一课
点赞 评论 收藏
分享
评论
点赞
5
分享

创作者周榜

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