快速排序與二分查找程序
下面是系統(tǒng)自帶快排和二分查找的函數(shù)。qsort和bsearch兩個(gè)函數(shù)可以配合起來(lái)用,先排序,在查找,也可以分開使用。qsort在比較兩個(gè)數(shù)大小的時(shí)候返回3個(gè)值,1、-1、0,改變1和-1的位置,就可以實(shí)現(xiàn)從大到小和從小到大排序。
qsort
功能:對(duì)數(shù)組base中nmemb塊大小為size字節(jié)的數(shù)組快速排序。
參數(shù):base 開始地址,nmenmb 數(shù)據(jù)塊數(shù) size 地址大小 compare 根據(jù)此指針指向的函數(shù)的返回結(jié)果來(lái)排序(0,正數(shù)和負(fù)數(shù))
返回值:無(wú)
bsearch
功能:從地址base 開始空間的nmenmb塊大小為size字節(jié)的數(shù)據(jù)中,二分查找key指針保存地址空間中的內(nèi)容
參數(shù):key查找內(nèi)容的首地址base開始地址nmenmb
//qsort 函數(shù)的使用
//bseach函數(shù)使用
#include
#include
int c_desc(const void *px,const void *py);
//int c_asc(const void *px,const void *py);
int main(){
intarr[10]={0};
inti=0,j=0,data=0;
int*p=&j;
printf("輸入十個(gè)數(shù):");
for(i=0;i<10;i++)
scanf("%d",&arr[i]);
printf("輸入查找的數(shù):");
scanf("%d",&data);
printf("升序排列:");
qsort(arr,10,sizeof(int),c_desc);
for(i=0;i<10;i++)
printf("%d",arr[i]);
printf("");
// printf("降序排列:");
// qsort(arr,10,sizeof(int),c_asc);
// for(i=0;i<10;i++)
// printf("%d",arr[i]);
p=bsearch(&data,arr,10,sizeof(int),c_desc);
if(p==NULL)
printf("不存在");
else{
printf("存在");
printf("%d在第%d個(gè)位置",data,p-arr+1);
}
printf("");
return0;
}
int c_desc(const void *px,const void *py){
const*p1=px;
const*p2=py;
if(*p1==*p2)
return0;
elseif(*p1>*p2)
return1;
else
return-1;
}
#if 0
int c_asc(const void *px,const void *py){
const*p1=px;
const*p2=py;
if(*p1==*p2)
return0;
elseif(*p1>*p2)
return-1;
else
return1;
}
關(guān)鍵詞:
快速排序二分查
相關(guān)推薦
技術(shù)專區(qū)
- FPGA
- DSP
- MCU
- 示波器
- 步進(jìn)電機(jī)
- Zigbee
- LabVIEW
- Arduino
- RFID
- NFC
- STM32
- Protel
- GPS
- MSP430
- Multisim
- 濾波器
- CAN總線
- 開關(guān)電源
- 單片機(jī)
- PCB
- USB
- ARM
- CPLD
- 連接器
- MEMS
- CMOS
- MIPS
- EMC
- EDA
- ROM
- 陀螺儀
- VHDL
- 比較器
- Verilog
- 穩(wěn)壓電源
- RAM
- AVR
- 傳感器
- 可控硅
- IGBT
- 嵌入式開發(fā)
- 逆變器
- Quartus
- RS-232
- Cyclone
- 電位器
- 電機(jī)控制
- 藍(lán)牙
- PLC
- PWM
- 汽車電子
- 轉(zhuǎn)換器
- 電源管理
- 信號(hào)放大器
評(píng)論