CArray使用qsort排序

2023-12-10 00:08
文章标签 使用 排序 qsort carray

本文主要是介绍CArray使用qsort排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

按照Str_pin从小到大排序

CWrap_LineDlg.h:
typedef int (__cdecl *GENERICCOMPAREFN)(const void * elem1, const void * elem2);
static int __cdecl Cmp(const Record** a,const Record** b);
struct Record {
double x1; //mm  //must
double y1;//must
double x2;//must
double y2;//must
int i;
int color;
int sep;//字串从X1开始的位置,后面为PIN の坐标点
int flag;
int bank_Probe;
int bank_Pin;
int index;
int bank_num;
float fpin_row;
float fpin_column;
float fprobe_row;
float fprobe_column;
CString str_pin; 
CString str_pin2;
CString str_pro;
CString str_all;
};
CArray<Record *, Record *> m_records;
CWrap_LineDlg.cpp:
int CWrap_LineDlg::Cmp(const Record** a,const Record** b)
{
ASSERT(*a);
ASSERT(*b);
return (*a)->str_pin.Compare((*b)->str_pin);//从大到小排序,调换a,b位置
}
qsort(m_records.GetData(),m_records.GetSize(),sizeof(Record*),(GENERICCOMPAREFN)Cmp);


 以下来自引用:

//#include ...
struct Data{
int nValue1;
int nValue2;
};
int cmp (const void *a, const void *b) 
{ 
int pa = ((Data*)a)->nValue1;
int pb = ((Data*)b)->nValue2;
return pb - pa; //降序
}
int main()
{
CArray<Data,Data&> ar;
Data data1;
data1.nValue1 = 10;
data1.nValue2 = 11;
Data data2;
data2.nValue1 = 20;
data2.nValue2 = 21;
ar.Add(data1);
ar.Add(data2);
qsort(&ar[0], ar.GetSize(), sizeof(Data&), cmp);
for(int i = 0; i < ar.GetSize(); ++i)
{
Data data3 = ar[i];
//...
}
return 0;
}

七种qsort排序方法

<本文中排序都是采用的从小到大排序>
一、对int类型数组排序
int num[100];
Sample:
int cmp ( const void *a , const void *b )
{
return *(int *)a - *(int *)b;
}
qsort(num,100,sizeof(num[0]),cmp);


二、对char类型数组排序(同int类型)
char word[100];
Sample:
int cmp( const void *a , const void *b )
{
return *(char *)a - *(int *)b;
}
qsort(word,100,sizeof(word[0]),cmp);


三、对double类型数组排序(特别要注意)
double in[100];
int cmp( const void *a , const void *b )
{
return *(double *)a > *(double *)b ? 1 : -1;
}
qsort(in,100,sizeof(in[0]),cmp);


四、对结构体一级排序
struct In
{
double data;
int other;
}s[100]
//按照data的值从小到大将结构体排序,关于结构体内的排序关键数据data的类型可以很多种,参考上面的例子写
int cmp( const void *a ,const void *b)
{
return ((In *)a)->data > ((In *)b)->data ? 1 : -1;
}
qsort(s,100,sizeof(s[0]),cmp);


五、对结构体二级排序
struct In
{
int x;
int y;
}s[100];
//按照x从小到大排序,当x相等时按照y从大到小排序
int cmp( const void *a , const void *b )
{
struct In *c = (In *)a;
struct In *d = (In *)b;
if(c->x != d->x) return c->x - d->x;
else return d->y - c->y;
}
qsort(s,100,sizeof(s[0]),cmp);


六、对字符串进行排序
struct In
{
int data;
char str[100];
}s[100];
//按照结构体中字符串str的字典顺序排序
int cmp ( const void *a , const void *b )
{
return strcmp( ((In *)a)->str , ((In *)b)->str );
}
qsort(s,100,sizeof(s[0]),cmp);

自己写一个纯字符串的:(temp是二维的字符串数组,j是一共需排序的字符串个数)

int cmpstr(const void *a,const void *b)
{
   return strcmp((char*)a,(char*)b);
}

    qsort(temp, j,sizeof(temp[0]),cmpstr);

七、计算几何中求凸包的cmp
int cmp(const void *a,const void *b) //重点cmp函数,把除了1点外的所有点,旋转角度排序
{
struct point *c=(point *)a;
struct point *d=(point *)b;
if( calc(*c,*d,p[1]) < 0) return 1;
else if( !calc(*c,*d,p[1]) && dis(c->x,c->y,p[1].x,p[1].y) < dis(d->x,d->y,p[1].x,p[1].y)) //如果在一条直线上,则把远的放在前面
return 1;
else return -1;
}

qsort()是c程序库stdlib.h中的一个函数,需要比较函数完成排序;
sort()是STL中的标准算法。
#include<stdlib.h>
int cmp(const void *a,const void *b)
{
    return *((int *)b)-*((int *)a);
}
    .
    .
     .
qsort(q,n,sizeof(int),cmp);
    .
    .
    .
}
qsort对一维数组和字符串数组的排序:
#include "stdio.h"
#include "stdlib.h"
int a[100];
int cmp(const void *p,const void *q)
{
    return (*(int*)p)-*((int*)q);
}
int main()
{
    int n;
    scanf("%d",&n);
    for(int i=0;i<n;i++)
        scanf("%d",&a[i]);
    qsort((void*)a,n,sizeof(a[0]),cmp);
    for(int i=0;i<n;i++)
      printf("%d\n",a[i]);
    //while(1);
   
int cmp(const void *p,const void *q)
{
    return strcmp((char*)p,(char*)q);
}
int main()return 0;
}

#include "stdio.h"
#include "stdlib.h"
#include "string.h"
char a[20005][25];
{
    int n,m,i,j;
    while(1)
    {
            scanf("%d%d",&n,&m);
            if(n==0&&m==0) break;
            for(i=0;i<n;i++)
            {
               scanf("%s",a[i]);
            }
            qsort((void*)a,n,sizeof(a[0]),cmp);
            for(i=0;i<n;i++)
               printf("%s\n",a[i]);
    }
}

 

这篇关于CArray使用qsort排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/475497

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

hdu 1285(拓扑排序)

题意: 给各个队间的胜负关系,让排名次,名词相同按从小到大排。 解析: 拓扑排序是应用于有向无回路图(Direct Acyclic Graph,简称DAG)上的一种排序方式,对一个有向无回路图进行拓扑排序后,所有的顶点形成一个序列,对所有边(u,v),满足u 在v 的前面。该序列说明了顶点表示的事件或状态发生的整体顺序。比较经典的是在工程活动上,某些工程完成后,另一些工程才能继续,此时