当前位置: 首页 > news >正文

大型网站改版网站建设与管理规定

大型网站改版,网站建设与管理规定,无法跳转到建设银行网站,网站统计有哪些目录 1.qsort函数的介绍 2.qsort函数的声明 3.qsort函数的使用 1.整形 2.浮点型 3.结构体类型 (1)一级排序 (2)多级排序 1.qsort函数的介绍 qsort函数能够排序任意数据类型的数组,如整形、浮点型、字符串以及结…

目录

1.qsort函数的介绍

2.qsort函数的声明

3.qsort函数的使用

1.整形

2.浮点型

3.结构体类型

(1)一级排序

(2)多级排序


1.qsort函数的介绍

qsort函数能够排序任意数据类型的数组,如整形、浮点型、字符串以及结构体类型。

qsort函数是库函数,在使用时应包含对应的头文件(#include<stdlib.h>)

2.qsort函数的声明

void qsort(void *base, size_t num, size_t width, int ( *compare)(const void *elem1,const void *elem2));

void *base:需要排序的数组的首元素的地址

size_t num:数组的元素个数

size_t width:数组元素的大小(所占字节数)

int (*compare)(const void* elem1, const void* elem2):该参数为函数指针,指向一个比较函数,在排序时,用来比较两个元素大小。两个参数(elem1, elem2)为所比较元素的地址,参数类型为void*,因此可以接收任意类型的参数。

返回类型为Int,elem1 < elem2时,返回<0的值;elem1 = elem2时,返回0;elem1 > elem2时,返回>0的值(此时排序为升序,若想将排序改为降序,只需在elem1 < elem2时返回>0的值,elem1 > elem2时,返回<0的值)

3.qsort函数的使用

1.整形

首先实现比较函数(cmp_int)

int cmp_int(const void* p1, const void* p2)
{return (*((int*)p1)) - (*(int*)p2);
}

 首先将指针强制类型转换为整形指针,再进行解引用获得元素的值,最后返回两个元素的差值。

再调用qsort函数

#include <stdio.h>
#include <stdlib.h>int cmp_int(const void* p1, const void* p2)
{return (*((int*)p1)) - (*(int*)p2);
}void test1()
{int arr[] = { 1,2,10,4,11,6,7,9,0 };int sz = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}printf("\n");qsort(arr, sz, sizeof(arr[0]), cmp_int);printf("排序后: ");for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}printf("\n");
}int main(){test1();return 0;
}

 排序结果

2.浮点型

 首先实现比较函数cmp_double

double为8字节,若直接返回两个元素的差值,此时强制类型转换为int,浮点类型不完整,则可能出现错误

 因此在处理时使用if else语句判断

int cmp_double(const void* p1, const void* p2)
{double ret = *(double*)p1 - *(double*)p2;if (ret > 0)return 1;else if (ret < 0)return -1;elsereturn 0;
}

再调用qsort函数

#include <stdio.h>
#include <stdlib.h>int cmp_double(const void* p1, const void* p2)
{double ret = *(double*)p1 - *(double*)p2;if (ret > 0)return 1;else if (ret < 0)return -1;elsereturn 0;
}void test2()
{double arr[] = { 1.3,3,2.1,0.9,1.7,10.3,9.1 };int sz = sizeof(arr) / sizeof(arr[0]);printf("排序前:");for (int i = 0; i < sz; i++){printf("%.2lf ", arr[i]);}printf("\n");qsort(arr, sz, sizeof(arr[0]), cmp_double);printf("排序后:");for (int i = 0; i < sz; i++){printf("%.2lf ", arr[i]);}printf("\n");
}int main(){test2();return 0;
}

排序结果

3.结构体类型

在对结构体类型进行排序时,首先要确定排序的依据

如结构体

struct stu
{
    int age;
    char name[10];
    double score;
};

 首先确定是依据年龄、姓名还是分数进行排序,或是进行多级排序,即先按分数排序,若分数相同,则按姓名排序。

(1)一级排序

按姓名进行排序

比较函数cmp_by_name

使用strcmp函数比较两个字符串的大小

int cmp_stu_by_name(const void* p1,const void* p2)
{return (strcmp(((struct stu*)p1)->name , ((struct stu*)p2)->name ));
}

调用qsort函数

#include <stdio.h>
#include <stdlib.h>
#include <string.h>struct stu
{int age;char name[10];double score;
};int cmp_stu_by_name(const void* p1,const void* p2)
{return (strcmp(((struct stu*)p1)->name , ((struct stu*)p2)->name ));
}void test3()
{struct stu students[3] = { {12,"li",90.5},{11,"zhang",80.3},{10,"wang",97.6} };int sz = sizeof(students) / sizeof(students[0]);printf("排序前:\n");for (int i = 0; i < sz; i++){printf("%d %s %.2lf", students[i].age, students[i].name, students[i].score);printf("\n");}printf("\n");qsort(students, sz, sizeof(students[0]), cmp_stu_by_name);//按名字排序printf("排序后:\n");for (int i = 0; i < sz; i++){printf("%d %s %.2lf", students[i].age, students[i].name, students[i].score);printf("\n");}printf("\n");
}int main(){test3();return 0;
}

 排序结果

(2)多级排序

先按照成绩排序,若成绩相同,则按照名字排序

比较函数cmp_stu

int cmp_stu(const void* p1, const void* p2)
{double ret = ((struct stu*)p2)->score - ((struct stu*)p1)->score;if (ret > 0)return 1;else if (ret < 0)return -1;elsereturn (strcmp(((struct stu*)p1)->name, ((struct stu*)p2)->name));
}

在成绩相同时,按照名字进行排序,若还要按照年龄排序,在名字相同时,按照年龄排序即可。 

调用qsort函数

#include <stdio.h>
#include <stdlib.h>
#include <string.h>struct stu
{int age;char name[10];double score;
};int cmp_stu(const void* p1, const void* p2)
{double ret = ((struct stu*)p2)->score - ((struct stu*)p1)->score;if (ret > 0)return 1;else if (ret < 0)return -1;elsereturn (strcmp(((struct stu*)p1)->name, ((struct stu*)p2)->name));
}void test3()
{struct stu students[] = { {12,"li",90.5},{11,"zhang",80.3},{10,"wang",97.6},{12,"zhao",80.3} };int sz = sizeof(students) / sizeof(students[0]);printf("排序前:\n");for (int i = 0; i < sz; i++){printf("%d %s %.2lf", students[i].age, students[i].name, students[i].score);printf("\n");}printf("\n");qsort(students, sz, sizeof(students[0]), cmp_stu);printf("排序后:\n");for (int i = 0; i < sz; i++){printf("%d %s %.2lf", students[i].age, students[i].name, students[i].score);printf("\n");}printf("\n");
}int main(){test3();return 0;
}

排序结果

http://www.yayakq.cn/news/310479/

相关文章:

  • 万网主机网站建设视频wordpress wp_signon
  • wordpress 微站什么是网站及其制作步骤
  • 网站建设哪家好 需要多少钱app开发公司哪家比较好
  • 短视频推广seo隐迅推专业外贸网站如何seo
  • 网站建设培训课程学了3个月ui好找工作吗
  • 网站 地区加关键词交换链接的方法
  • 公司做网站需要什么条件网站地图模板下载
  • 太原定制网站制作流程网站设计与制作报价
  • 网站建设二级关键词什么意思增加网站产品
  • 网站建设解决问题深圳网络营销公司排行榜
  • 甘肃建设项目公示网站天元建设集团有限公司商业承兑汇票
  • 网页设计作业 个人网站上海装修公司咨询
  • 公路建设管理办公室网站重庆百度
  • 兼职做网站在那里接任务东莞网站建设建网站
  • 设置网站默认编码网站开发静态和动态
  • 陕西天工建设有限公司官方网站企业做网站etp和源程序
  • 网站还未被收录可以做推广吗网站分为哪些结构
  • 奇信建设集团官方网站如何做vip电影解析网站
  • 邹城市建设局网站美摄短视频sdk
  • 郫都区规划建设局网站广州seo培训课程
  • 国外对企业网站开发的研究文网文网站建设
  • 一个网站突然打不开网站代码组件
  • 鲜花网站建设项目策 划书花瓣网平面设计素材
  • 建设兼职网站目的郑州网络推广平台有哪些
  • 网站注销网站开发有前途么
  • 昆明餐饮网站建设中国菲律宾世预赛直播
  • 网络营销效果好的网站平台开发者
  • 做网站需要会哪些知识四川公共交易资源信息网
  • 云主机建多个网站网站在线订单系统怎么做
  • html5 网站 源码添加网站描述