sort:

一、对int类型数组排序

int a[100];

int cmp ( int a , int b ) //不必强制转换

{

return a < b;//升序排列。

sort (a(数组名) , a+100(数组最后一个元素), cmp);

头文件 #include<algorithm>,属于C++中STL

qsort:

一、对int类型数组排序

int a[100];

int cmp ( const void *a , const void *b ) //此处必须强制转换

{

return *(int *)a - *(int *)b;//升序排列。

所以在前面的字符的值一定小于后面的字符。

那么,对于a b,如果a的值>b的值,就说明在字母表中a在b的后面

}

qsort(a(数组名),100(数组长度),sizeof(a[0])(数组元素的宽度),cmp);  头文件#include <stdlib.h>

bsearch :(一般与qsort连用)

以int 型数组为例

bsearch 返回一个地址

int *p;

  1. p = (int *)bsearch(&k(关键字地址), a(数组名), n(数组长度), sizeof(a[0]), cmp);//C++需要(int *)强制转换,C不用
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int cmp(const void *p, const void *q)
  4. {
  5. return (*(int *)p - *(int *)q);
  6. }
  7. int main()
  8. {
  9. int a[1000001];
  10. int n,k,*p;
  11. while(~scanf("%d",&n))
  12. {
  13. for(int i = 0;i<n;i++)
  14. {
  15. scanf("%d",&a[i]);
  16. }
  17. scanf("%d",&k);
  18. qsort(a, n, sizeof(a[0]), cmp);
  19. p = bsearch(&k, a, n, sizeof(a[0]), cmp);
  20. (p == NULL) ? puts("NO") : puts("YES");
  21. }
  22. return 0;
  23. }

最新文章

  1. 编写BinIoDemo.java的Java应用程序,程序完成的功能是:完成1.doc文件的复制,复制以后的文件的名称为自己的学号姓名.doc。
  2. mac安装chromedriver报错
  3. css3学习总结5--CSS3文本效果
  4. CSS_03_01_CSS组合选择器
  5. Oracle安装后,服务中没有监听器怎么处理?
  6. maven小项目注册服务(一)--email和persist模块
  7. ajax提交数据Demo
  8. Spring的OpenEntityManagerInViewFilter
  9. Linq101-Set
  10. Android - 硬件抽象层(HAL)
  11. C语言的本质(14)——不完全类型和复杂声明
  12. javascript继承之借用构造函数与原型
  13. 转载:org.apache.catalina.util.DefaultAnnotationProcessor cannot be cast to org.apache.Annotation
  14. C++类的存储(部分可用与c的结构体)
  15. Nginx http和https 共存
  16. 一张图看懂STM32芯片型号的命名规则
  17. Docker学习资源
  18. Mysql数据库单表查询
  19. python之线程相关操作(补充)
  20. 互联网,IT,大数据,机器学习,AI知识tag云

热门文章

  1. mtr
  2. Orleans学习总结(四)--集群配置篇
  3. 关于linux-Centos 7下mysql 5.7.9的rpm包的安装方式
  4. SVM 核方法
  5. hashlib模块configparser模块logging模块
  6. PHP链接MySQL,查询数据库内容,删除数据库内容。。。记住链接公式!!!
  7. git提交出现这个界面怎么退出
  8. SpringMVC中@RestController的用法
  9. 异常could not retrieve snapshot
  10. CentOS7初始化mysql库报错