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

做哪些网站流量大微信crm管理系统

做哪些网站流量大,微信crm管理系统,成免费crm是什么,盗图来做网站目录 1.回顾回调函数 2.写一个bubble_sort函数 2.1认识一下qsort函数 ​编辑2.2写bubble_sort函数 今天我们继续深入学习指针 1.回顾回调函数 我们回顾一下之前学过的回调函数 回调函数就是一个通过函数指针调用的函数 如果你把函数的指针(地址)…

目录

1.回顾回调函数

2.写一个bubble_sort函数

2.1认识一下qsort函数

​编辑2.2写bubble_sort函数


今天我们继续深入学习指针

1.回顾回调函数

我们回顾一下之前学过的回调函数

回调函数就是一个通过函数指针调用的函数

如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数

回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外 的一方调用的,用于对该事件或条件进行响应

2.写一个bubble_sort函数

2.1认识一下qsort函数

同样,我们在cplusplus网站里学习一下

qsort - C++ Reference (cplusplus.com)

2.2写bubble_sort函数

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void qsort
//qsort底层使用的是快速排序
(void* base,//指向待排序数据的起始地址size_t num,//待排序数据的元素个数size_t size,//待排序数据的一个元素的大小,单位是字节int(*cmp)(const void* e1, const void* e2)//函数指针,指向一个比较函数,这个函数是用来比较2个元素的
);
int cmp_int(const void* e1, const void* e2)
{return *(int*)e1 - *(int*)e2;
}
struct Stu
{char name[20];int age;
};
int cmp_by_age(const void* e1, const void* e2)
{return ((struct Stu*)e1)->age - ((struct Stu*)e2)->age;
}
int cmp_by_name(const void* e1, const void* e2)
{return strcmp(((struct Stu*)e1)->name , ((struct Stu*)e2)->name);
}
void swap(char* buf1, char* buf2, size_t size)
{int i = 0;for (i = 0; i < size; i++){char tmp = *buf1;*buf1 = *buf2;*buf2 = tmp;buf1++;buf2++;}
}//使用冒泡排序的算法,模拟实现一个排序函数,可以排序任意类型的数据
//bubble_sort()
void bubble_sort(void* arr,size_t sz,size_t size, int(*cmp)(const void* e1, const void* e2))
{//冒泡排序的趟数int i = 0;for (i = 0; i < sz - 1; i++){//一趟冒泡排序int j = 0;for (j = 0; j < sz - 1 - i; j++){if (cmp((char*)arr+j*size,(char*)arr+(j+1)*size)>0){swap((char*)arr + j * size, (char*)arr + (j + 1) * size,size);}}}
}
//int(*cmp)(const void* e1, const void* e2)//e1是一个指针,存放了要比较的一个元素的地址//e2是一个指针,存放了要比较的一个元素的地址//e1指向的元素大于e2指向的元素,返回一个>0的数字//e1指向的元素等于e2指向的元素,返回0//e1指向的元素小于e2指向的元素,返回一个<0的数字
void print_arr(int arr[], int sz)
{for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}printf("\n");
}
void test1()
{int arr[] = { 9,8,7,6,5,4,3,2,1,0 };//降序//排序为升序int sz = sizeof(arr) / sizeof(arr[0]);print_arr(arr, sz);bubble_sort(arr, sz,sizeof(arr[0]),cmp_int);print_arr(arr, sz);
}
void test2()
{struct Stu arr[] = { { "zhangsan",20 } ,{ "lisi", 18 }, { "wangwu", 12 } };int sz = sizeof(arr) / sizeof(arr[0]);bubble_sort(arr, sz, sizeof(arr[0]),cmp_by_age);bubble_sort(arr, sz, sizeof(arr[0]), cmp_by_name);}
int main()
{//test1();//测试排序整型数据test2();//测试排序结构体数据return 0;
}

这里我们写的bubble_sort函数是升序的排序,具体的实现细节,我们后面的文章会分析

http://www.hyszgw.com/news/1178.html

相关文章:

  • 公司网站建设设计公司排名公司软文
  • wordpress 多个页面吉林seo基础知识
  • 做水果生意去那个网站seo分析师招聘
  • wordpress 按点击调用热门文章seo工资
  • 东莞网站建设服务网页版百度
  • 中山网站建设招聘公司推广文案
  • 有没有做公章的网站河南推广网站
  • 微信app网站建设深圳华强北最新消息
  • 建设部一建注册公示网站国际婚恋网站排名
  • 53套网站源码国外搜索引擎大全不屏蔽
  • wordpress首页不显示文章武汉百度seo网站优化
  • 盐城网站平台建设3a汽车集团公司网络营销方案
  • 多语言网站建设费用uc信息流广告投放
  • 羽毛球网站建设网站考研培训机构排名前十
  • ASP 动态网站建设seo博客写作
  • wordpress 注册审批网站优化最为重要的内容是
  • 成全视频免费观看在线看游戏新乡seo公司
  • 信阳网站网站建设广告公司的业务范围
  • 泰安集团网站建设报价提升seo排名
  • 自媒体平台注册头条号山西seo关键词优化软件搜索
  • 成都大型商城网站建设百度手游app下载
  • 网站 后台搜索引擎优化缩写
  • 学电子商务去哪个学校比较好seo优化方案总结
  • 软件企业网站建设栏目结构图网站网络推广公司
  • 万网的网站建设排名优化方法
  • 什么站做咨询网站好谷歌浏览器chrome官网
  • 厦门建设厅查询网站技能培训学校
  • 网站建设 域名 数据库太原seo网站优化
  • 怎么建设公司小程序网站郑州网络营销
  • 做多语言网站多少钱家庭优化大师