• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 8, 文章 - 1, 評(píng)論 - 14, 引用 - 0
            數(shù)據(jù)加載中……

            基礎(chǔ)排序查找算法

            二分查找:
             binarysearch考的比較多,它適用于已經(jīng)排序的元素中的查找

             int binarySearch(int a[],int len,int value)
            {
                int low = 0;
                
            int high = len -1;    
                
                
            while(low<=high)   //注意搜索條件,有可能兩者會(huì)相等
                {
                    
            int mid = (low+high)/2;
                    
            if(a[mid]==value) return mid;
                    
            else if(a[mid]>value) high = mid -1;            
                    
            else low = mid + 1;    
                }
                
            return -1;
            }

            int main()
            {
                
            int a[] = {1,2,3,4,5,6,7,8,9,10};
                
            int rec = binarySearch(a,10,4);
                
            if(rec==-1)
                    printf(
            "Not found\n");
                
            else
                    printf(
            "value is found %d \n",rec);
                
            return 0;
            }
             
             快速排序
             對(duì)冒泡算法的擴(kuò)展
             
              int partition(int a[],int low,int high)
            {
                int temp = a[low];
                
            while(low<high)
                {
                    while(low<high && a[high]>=temp) --high;
                    a[low] 
            = a[high];
                    
            while(low<high && a[low]<=temp)  ++low;
                    a[high] 
            = a[low];
                }
                
                a[low] 
            = temp;
                
            return low;
            }
                



            void Qsort(int a[],int begin,int end)
            {
                
            int rec;
                
            if(begin<end)
                {
                    rec 
            = partition(a,begin,end);
                    printf(
            "rec is %d\n",rec);                
                    Qsort(a,begin,rec
            -1);
                    Qsort(a,rec
            +1,end);
                }
            }

            int main()
            {
                
            int  a[] = {1,4,0,-3,90,7,9,23};
                Qsort(a,
            0,7);
                
            int i =0;
                
            for(;i<8;i++)
                    printf(
            "%d\t",a[i]);

                
            return 0;
            }
             
              
              

            posted on 2011-08-19 18:28 兵臨城下 閱讀(1864) 評(píng)論(4)  編輯 收藏 引用 所屬分類: 算法

            評(píng)論

            # re: 基礎(chǔ)排序查找算法[未登錄](méi)  回復(fù)  更多評(píng)論   

            這種二分查找除了考試幾乎沒(méi)有一點(diǎn)實(shí)用價(jià)值。通常使用的二分查找用于找一個(gè)序列的上界或下界。請(qǐng)到我主頁(yè)上看看原地歸并排序,有二分查找的相關(guān)代碼。

            用第一個(gè)元素做支點(diǎn)進(jìn)行劃分,請(qǐng)想一想當(dāng)待排序序列為逆序時(shí)它將退化成冒泡排序,那會(huì)有多慢吧?就算用隨機(jī)序列,這種快速排序恐怕也慢的不能接受,請(qǐng)到我主頁(yè)上看看快速排序的前兩個(gè)版本怎么設(shè)計(jì)的,就算最慢的原始版本(第3個(gè)版本),相信也會(huì)比你的這種快排快得多。

            唉,可惡的中國(guó)計(jì)算機(jī)教育啊,誤人子弟一批又一批,不知道還會(huì)繼續(xù)多少批...
            2011-08-19 21:26 | Chipset

            # re: 基礎(chǔ)排序查找算法  回復(fù)  更多評(píng)論   

            不全啊
            2011-08-19 23:07 | 向振偉

            # re: 基礎(chǔ)排序查找算法  回復(fù)  更多評(píng)論   

            @Chipset

            這種二分查找除了考試幾乎沒(méi)有一點(diǎn)實(shí)用價(jià)值??????????????? 上層做多的人一般會(huì)這么回復(fù)
            2011-08-22 17:48 | 過(guò)路客

            # re: 基礎(chǔ)排序查找算法[未登錄](méi)  回復(fù)  更多評(píng)論   

            @過(guò)路客
            除了考試這種二分查找哪里用上了,我見識(shí)短淺,拜托您舉個(gè)例子吧:-)

            當(dāng)隨機(jī)查找一個(gè)值時(shí)通常用哈希,不需要二分查找,因?yàn)槎植檎腋1绕饋?lái)慢多了,如果各個(gè)元素之間需要保持相對(duì)順序的話(假設(shè)可能有重復(fù)的),通常是查找上界或下界,用的是樓主這個(gè)二分查找的變形版本(看看STL lower_bound和upper_bound以及equal_range),而這個(gè)既非找上界也非找下界的二分查找在實(shí)際應(yīng)用中幾乎就是個(gè)廢物!
            2011-08-25 13:24 | Chipset

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            亚洲精品高清国产一久久| 青青久久精品国产免费看| 亚洲国产视频久久| 狠狠色丁香婷婷久久综合五月| 久久综合偷偷噜噜噜色| 日韩AV无码久久一区二区| 97久久精品无码一区二区| 思思久久99热只有频精品66 | 久久精品国产久精国产果冻传媒| 无码人妻久久一区二区三区| 久久人人爽人人精品视频| 久久亚洲日韩精品一区二区三区| a级毛片无码兔费真人久久| 奇米影视7777久久精品| 久久狠狠一本精品综合网| 久久九九免费高清视频| 麻豆一区二区99久久久久| 天堂无码久久综合东京热| 伊人久久大香线蕉精品| 久久综合综合久久综合| 2021国产精品久久精品| 国产国产成人久久精品| 狠色狠色狠狠色综合久久| 麻豆精品久久精品色综合| 国产精品久久国产精麻豆99网站| 亚洲va久久久久| 色播久久人人爽人人爽人人片aV| 久久精品国产半推半就| 久久99久久99小草精品免视看| 性高湖久久久久久久久| 久久婷婷国产综合精品 | 日韩精品国产自在久久现线拍| 一本一本久久aa综合精品| 精品多毛少妇人妻AV免费久久| 久久久久这里只有精品| 亚洲精品国产综合久久一线| 色综合久久无码五十路人妻| 亚洲色婷婷综合久久| 久久精品中文闷骚内射| 色偷偷888欧美精品久久久| 久久亚洲精品中文字幕三区|