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

一组数按个位数从大到小排列,个位数相同的按实际大小排列,有没有啥好的算法来解?
我只会笨办法= =!
#笔试题目#
全部评论
写个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

相关推荐

每晚夜里独自颤抖:你cet6就cet6,cet4就cet4,你写个cet证书等是什么意思。专业技能快赶上项目行数,你做的这2个项目哪里能提现你有这么多技能呢
点赞 评论 收藏
分享
06-18 13:28
已编辑
门头沟学院 Web前端
爱睡觉的冰箱哥:《给予你300的工资》,阴的没边了
点赞 评论 收藏
分享
评论
点赞
5
分享

创作者周榜

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