各种基本算法实现小结(六)—— 查找算法

 

 

转载地址:http://blog.youkuaiyun.com/sunboy_2050/article/details/5645835

 

各种基本算法实现小结(六)—— 查找算法

(均已测试通过)

===================================================================

1、简单查找

在一组无序数列中,查找特定某个数值,并返回其位置pos

测试环境:VC 6.0 (C)

[cpp:showcolumns] view plain copy print ?
·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150
  1. #include <stdio.h> 
  2. #include <stdlib.h> 
  3. #include <time.h> 
  4. #define MAX 101 
  5. void input(int num[]) 
  6.     int i; 
  7.      
  8.     srand((unsigned)time(NULL)); 
  9.     for(i=1; i<MAX; i++) 
  10.         num[i]=rand()%100; 
  11. void output(int num[]) 
  12.     int i; 
  13.      
  14.     for(i=1; i<MAX; i++) 
  15.     { 
  16.         printf("%5d", num[i]); 
  17.         if(0==i%10) 
  18.             printf("/n"); 
  19.     } 
  20. int find(int num[], int x) 
  21.     int i; 
  22.     for(i=1; i<MAX; i++) 
  23.         if(x == num[i]) 
  24.             return i; 
  25.     return 0; 
  26. void main() 
  27.     int x, pos, num[MAX]; 
  28.     input(num); 
  29.      
  30.     printf("num...: /n"); 
  31.     output(num); 
  32.      
  33.     printf("Enter find num: "); 
  34.     scanf("%d", &x); 
  35.     pos=find(num, x); 
  36.     if(pos) 
  37.         printf("OK! %d is found in pos: %d/n", x, pos); 
  38.     else 
  39.         printf("Sorry! %d is not found... in num/n", x); 

运行结果:

 

==========================================================

2、 折半查找

在有序数列中,逐步缩小查找范围,直至找到或找不到记录为止

本算法首先随机生成100个无序数列,然后利用快速排序算法排序成有序数列,然后再用折半查找算法

说明:本算法中的排序算法,可用上一篇排序算法中的任一种算法实现,如选择排序、冒泡排序、快速排序等

测试环境:VC 6.0 (C)

[cpp:showcolumns] view plain copy print ?
·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150
  1. #include <stdio.h> 
  2. #include <stdlib.h> 
  3. #include <time.h> 
  4. #define MAX 101 
  5. void input(int num[]) 
  6.     int i; 
  7.      
  8.     srand((unsigned)time(NULL)); 
  9.     for(i=1; i<MAX; i++) 
  10.         num[i]=rand()%100; 
  11. void output(int num[]) 
  12.     int i; 
  13.      
  14.     for(i=1; i<MAX; i++) 
  15.     { 
  16.         printf("%5d", num[i]); 
  17.         if(0==i%10) 
  18.             printf("/n"); 
  19.     } 
  20. void sort(int num[], int low, int high) /* quick sort */ 
  21.     int l, h; 
  22.      
  23.     if(low<high) 
  24.     { 
  25.         l=low; 
  26.         h=high; 
  27.         num[0]=num[l]; /* save pivot */ 
  28.          
  29.         while(l<h) 
  30.         { 
  31.             while(l<h && num[h]>=num[0]) h--; 
  32.                 num[l]=num[h]; 
  33.             while(l<h && num[l]<=num[0]) l++; 
  34.                 num[h]=num[l]; 
  35.         } 
  36.         num[l]=num[0]; /* insert pivot */ 
  37.          
  38.         sort(num, low, l-1); 
  39.         sort(num, l+1, high); 
  40.     } 
  41. int find(int num[], int x, int low, int high) 
  42.     int mid; 
  43.      
  44.     while(low<=high) 
  45.     { 
  46.         mid=(low+high)/2; /* find is OK */ 
  47.          
  48.         if(x==num[mid]) 
  49.             return mid; 
  50.         else if(x<num[mid]) 
  51.             high=mid-1; 
  52.         else 
  53.             low=mid+1; 
  54.     } 
  55.     return 0; 
  56. void main() 
  57.     int x, pos, num[MAX]; 
  58.     input(num); 
  59.      
  60.     printf("sort before... /n"); 
  61.     output(num); 
  62.     sort(num, 1, MAX-1); 
  63.     printf("sort after... /n"); 
  64.     output(num); 
  65.      
  66.     printf("Enter find num: "); 
  67.     scanf("%d", &x); 
  68.     pos=find(num, x, 1, MAX-1); 
  69.     if(pos) 
  70.         printf("OK! %d is found in pos: %d/n", x, pos); 
  71.     else 
  72.         printf("Sorry! %d is not found... in num/n", x); 

运行结果:

  

==========================================================

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值