首页 > 其他分享 >qlist 对结构体排序

qlist 对结构体排序

时间:2023-09-02 13:22:38浏览次数:32  
标签:return int list num test 排序 qlist 结构

结构体排序:

写法一

QList<test> s;
test aa;
test bb;
test cc;
aa.num = "14";
bb.num = "2";
cc.num = "3";
s.append(aa);
s.append(bb);
s.append(cc);


qSort(s.begin(), s.end(),[](const test &infoA,const test &infoB){return infoA.num.toDouble() < infoB.num.toDouble();});


for(int i = 0; i < s.count() ; i++)
{
qDebug() << s.at(i).num;
}

 


写法二

#include "widget.h"
#include <QApplication>
#include <QtDebug>


//排列判断
int compare(const test &infoA,const test &infoB)
{
return infoA.num.toDouble() < infoB.num.toDouble();
}


int main(int argc, char *argv[])
{
QApplication a(argc, argv);


QList<test> s;
test aa;
test bb;
test cc;
aa.num = "14";
bb.num = "2";
cc.num = "3";
s.append(aa);
s.append(bb);
s.append(cc);


qSort(s.begin(), s.end(),compare);


for(int i = 0; i < s.count() ; i++)
{
qDebug() << s.at(i).num;
}


return a.exec();
}

Qt中可以使用qSort可以对容器排序,助手中有很多示例,大多数关于int、QString的排序,今天这里主要讲解qSort如何对结构体进行排序的。

Qt对整形排序:

QList list;
list << 33 << 12 << 68 << 6 << 12;
qSort(list.begin(), list.end());
// list: [ 6, 12, 12, 33, 68 ]
Qt对字符串排序:

bool caseInsensitiveLessThan(const QString &s1, const QString &s2)
{
return s1.toLower() < s2.toLower();
}

int doSomething()
{
QStringList list;
list << "AlPha" << "beTA" << "gamma" << "DELTA";
qSort(list.begin(), list.end(), caseInsensitiveLessThan);
// list: [ "AlPha", "beTA", "DELTA", "gamma" ]
}
Qt对结构体排序:

struct BarAmount
{
int barLevel; //钢筋级别
QString diameter; //钢筋直径
double planAmount; //计划量
double purchaseAmount; //采购量
double amount; //总量
};
结构体如上所示, 对QList barDataList可通过以下方式进行排序!

void OverdraftControl::sortBarData(QList *barDataList)
{
qSort(barDataList->begin(), barDataList->end(), compareBarData);
}
bool compareBarData(const BarAmount &barAmount1, const BarAmount &barAmount2)
{
if (barAmount1.barLevel < barAmount2.barLevel)
{
return true;
}
else if (barAmount1.barLevel > barAmount2.barLevel)
{
return false;
}
else
{
QString strDiameter1 = barAmount1.diameter;
QString strDiameter2 = barAmount2.diameter;
int nCompare = compareDiameterDescription(strDiameter1,strDiameter2);
if (nCompare == -1)
{
return true;
}
else if (nCompare == 1)
{
return false;
}
else
{
return true;
}
}
}
直接调用sortBarData(&barDataList)就可以完成对QList barDataList的排序了!

标签:return,int,list,num,test,排序,qlist,结构
From: https://www.cnblogs.com/robinner/p/17673587.html

相关文章

  • 常用的七大排序算法
    1.七大排序算法简述1.1选择排序算法思想:进行n轮操作在某一轮中,选择未排序的一个最小数组元素,与右侧未排序的第一个数组元素交换交换完之后,相当于向右扩大已排序的数组范围。重复2,3.直至所有数组元素已排序稳定性:不稳定假设在某一轮数组状态为:1,2,3,8,8,4。已排序的元......
  • 基数排序
     基数排序,不是基于比较的排序。过程如下:处理过程:  桶排过程:1voidBucket_sort(inta[],intexp)//exp为1按个位排序,exp为10按十位排序,exp为100按个位排序,……2{3vector<int>Bucket[20];45//按位入桶,+10是为了对付负数6for(int......
  • Redis核心数据结构与高性能原理(1)
    Redis安装下载地址:http://redis.io/download安装步骤:#安装gccyuminstallgcc#把下载好的redis-5.0.3.tar.gz放在/usr/local文件夹下,并解压wgethttp://download.redis.io/releases/redis-5.0.3.tar.gztar-zxvfredis-5.0.3.tar.gzcdredis-5.0.3#进入到解压好的......
  • 计算机体系结构量化学习方法-学习笔记0(i7 存储层次结构)
    1、interi7所用层次结构内容​ 修改处DataDLB(DataTLB).​ 2、Interi7存储器层次结构及指令与数据访问步骤图 3、指令与数据访问步骤:指令地址的页帧(36bit)被发送给指令TLB(①)。同时虚拟地址的12位页内偏移量被发送给指令缓存(ICACHE).对于8路组相连cache来说,缓存需要......
  • 2.分支结构-习题
    1.偶数【题目描述】读入一个正整数a,如果a为偶数输出yes。【输入】一个正整数a。【输出】偶数输出yes,否则什么也不输出。【输入样例】12【输出样例】yesinta;scanf("%d",&a);if(a%2==0){ printf("yes");}2.范围判断【题目描述】读入一个整数,若这个数大于1......
  • COMP3506数据结构与算法
    AssignmentOne–15%AlgorithmsandDataStructures–COMP3506/7505–Semester2,2023Due:3pmonFridaySeptember1st(week6)SummaryThemainobjectiveofthisassignmentistogetyourhandsdirtywithsomesimpledatastructuresandalgorithmstosolveb......
  • 数据结构与算法——深度寻路算法
    ......
  • 手撕数据结构与算法——树(三指针描述一棵树)
    ......
  • 数据结构与算法——栈和队列<也不过如此>
    ......
  • 数据结构与算法——二叉树+带你实现表达式树(附源码)
    ......