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;
p = (int *)bsearch(&k(关键字地址), a(数组名), n(数组长度), sizeof(a[0]), cmp);//C++需要(int *)强制转换,C不用
#include <stdio.h>
#include <stdlib.h>
int cmp(const void *p, const void *q)
{
return (*(int *)p - *(int *)q);
}
int main()
{
int a[1000001];
int n,k,*p;
while(~scanf("%d",&n))
{
for(int i = 0;i<n;i++)
{
scanf("%d",&a[i]);
}
scanf("%d",&k);
qsort(a, n, sizeof(a[0]), cmp);
p = bsearch(&k, a, n, sizeof(a[0]), cmp);
p == NULL) ? puts("NO") : puts("YES");
}
return 0;
}