算法导论(三)——分治法

divide conquer combine分而治之:

例子:

xn次方: a^n传统的做法就是循环相乘n次,算法效率为Θ(n)。但是如果采用分治法的思想,算法效率可以提高到Θ(lgn)

二分查找;归并排序;

快速排序;http://www.cnblogs.com/zhoutaotao/p/3970099.html(快排,随机快排)

斐波那契数列http://www.cnblogs.com/zhoutaotao/p/3964997.html(朴素递归,朴素递归平方,自底向上o(n),平方递归o(logn)

矩阵乘法;电路板的二叉树分布

最大最小问题的非递归解法

【用状态空间法分析,最大最小问题的比较次数的下限,当元素个数为奇数,,当其为偶数时,

template<class T>

bool maxmin(T a[], int n, int&indexofMax, int& indexofMin) {

       //Specialcase

       if(n < 1) return false;

       if(n == 1) {

              indexofMax= indexofMin = 0;

              returntrue;

    }

 //Initialization(Odd and even)

       ints = 1;//start index

       if(n % 2 == 1) {

              indexofMax= indexofMin = 0;

       }

       else{

              s= 2;

              if(a[0] >= a[1]) {

                     indexofMax= 0;

                     indexofMin= 1;

              }

              else{

                     indexofMax= 1;

                     indexofMin= 0;

              }

       }

       //mainprocess

       for(int i = s;i < n;i+=2) {

           if(a[i]<a[i+1]){

                     if(a[i] < a[indexofMin])

                            indexofMin= i;

                     if(a[i+1] > a[indexofMax])

                            indexofMax= i+1;

       }

              else{

                     if(a[i+1] < a[indexofMin])

                            indexofMin= i+1;

                     if(a[i ] > a[indexofMax])

                            indexofMax= i;

              }     

       }

       returntrue;

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值