求QList中最后三十个元素中最大一个数

彩阳 2013-04-19 04:50:14
如题。假设有一个QList<int> rates,如果rates的size()不足30那么求size()个元素中最大的数,如果size()大于30那么求rates最后三十个元素中最大的一个数,程序该怎么写好?
...全文
1149 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
超开心~ 2013-04-24
  • 打赏
  • 举报
回复
引用 4 楼 jiangcaiyang123 的回复:
引用 1 楼 chengchaooppo 的回复:int start = max(0,rates.size() - 30); //求一下较大者; int maxNum = rates[start]; for(int i = start,i<rates.size();i++) { if(rates[i] > maxNum) { ……
max函数是要自己写的,就是求二者之间的较大者,比较简单我就没有写了 int max(int a,int b) { if(a>b)return a; else return b; }
彩阳 2013-04-19
  • 打赏
  • 举报
回复
引用 3 楼 jdwx1 的回复:
如果list的size大于30,用QList<T> QList::mid(int pos, int length = -1) const取出后30个。
可惜不能从右开始取,不过思路还是给了我一些启发:

// 首先从右开始取,取到30个为止,不够也停止了
// 然后对取出的数组排序(默认升序)
// 最后用last()成员函数求出最后一个元素即为最大
就是代码怎样写才简练。
彩阳 2013-04-19
  • 打赏
  • 举报
回复
引用 1 楼 chengchaooppo 的回复:
int start = max(0,rates.size() - 30); //求一下较大者; int maxNum = rates[start]; for(int i = start,i<rates.size();i++) { if(rates[i] > maxNum) { maxNum = rates[i]; ……
不对,Linux中提示没有max。
jdwx 2013-04-19
  • 打赏
  • 举报
回复
如果list的size大于30,用QList<T> QList::mid(int pos, int length = -1) const取出后30个。
jdwx 2013-04-19
  • 打赏
  • 举报
回复
QList<int> list; list << 33 << 12 << 68 << 6 << 12; qSort(list.begin(), list.end()); // list: [ 6, 12, 12, 33, 68 ]
引用 楼主 jiangcaiyang123 的回复:
如题。假设有一个QList<int> rates,如果rates的size()不足30那么求size()个元素中最大的数,如果size()大于30那么求rates最后三十个元素中最大的一个数,程序该怎么写好? QList Qt ……
超开心~ 2013-04-19
  • 打赏
  • 举报
回复
int start = max(0,rates.size() - 30); //求一下较大者; int maxNum = rates[start]; for(int i = start,i<rates.size();i++) { if(rates[i] > maxNum) { maxNum = rates[i]; } }

16,213

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧