《程序设计实践》读书笔记一

作者:朱金灿<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

来源:http://blog.csdn.net/clever101

  1. #include<stdio.h>
  2. #include<string.h>
  3. char*flab[]=
  4. {
  5. "actually",
  6. "just",
  7. "quite",
  8. "really",
  9. NULL
  10. };
  11. //顺序检索法算法
  12. intlookup(char*word,char*array[])
  13. {
  14. inti;
  15. for(i=0;array[i]!=NULL;i++)
  16. {
  17. if(strcmp(word,array[i])==0)
  18. {
  19. returni;
  20. }
  21. }
  22. return-1;
  23. }
  24. intmain(intargc,char*argv[])
  25. {
  26. printf("%d/n",lookup("quite",flab));
  27. return0;
  28. }
  29. typedefstructNamevalNameval;
  30. structNameval
  31. {
  32. char*name;
  33. intvalue;
  34. };
  35. Namevalhtmlchars[]=
  36. {
  37. "AElig",0x00c6,
  38. "Aacute",0x00c1,
  39. "Acirc",0x00c2,
  40. "zeta",0x03b6
  41. };
  42. //二分检索法源码
  43. intlookup2(char*name,Namevaltab[],intntab)
  44. {
  45. intlow,high,mid,cmp;
  46. low=0;
  47. high=ntab-1;
  48. while(low<=high)
  49. {
  50. mid=(low+high)/2;
  51. cmp=strcmp(name,tab[mid].name);
  52. if(cmp<0)
  53. high=mid-1;
  54. elseif(cmp>0)
  55. low=mid+1;
  56. else
  57. returnmid;
  58. }
  59. return-1;
  60. }

二分检索只能用在元素已经排好序的数组上。如果需要对某个数据集反复进行检索,先把它排序,然后再用二分检索就会是很值得的。如果数据集事先已经知道,写程序时就可以直接将数据排好序,利用编译时的初始化构建数组。

最好的排序算法之一是快速排序(quicksort)。快排的工作方式是:

从数组中取出一个元素(基准值)。

把其他元素分为两组:

“小的”是那些小于基准值的元素;

“大的”是那些大于基准值的元素。

递归地对这两个组做排序。

快排算法的一种实现如下:

  1. voidquicksort(intv[],intn)
  2. {
  3. inti,last;
  4. if(n<=1)
  5. return;
  6. //随机抽取数组的元素作为基准元素,并将它和第一个元素交换
  7. swap(v,0,rand()%n);
  8. last=0;//用于保存基准元素应该放置的位置
  9. //以基准元素为界,将数组元素分为两组
  10. for(i=0;i<n;i++)
  11. {
  12. if(v[i]<v[0])
  13. {
  14. swap(v,++last,i);
  15. }
  16. }
  17. //将基准元素放在数组准确的位置中
  18. swap(v,0,last);
  19. //对数组的前一部分进行快速排序
  20. quicksort(v,last);
  21. //对数组的后一部分进行快速排序
  22. quicksort(v+last+1,n-last-1);
  23. }

这时我脑海中产生的一个问题是:在一般情况下采用快排+二分检索是不是就比顺序检索快呢?思考:使用循环方式实现快排算法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值