• <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>
            int Partition(double *Array,int left,int right)
            {
                
            double pivot=Array[left];
                
            int i=left;
                
            double tmp;
                
            for (int j=left+1;j<=right;j++)
                {
                    
            if (Array[j]<=pivot)
                    {
                        i
            ++;
                        tmp
            =Array[j];
                        Array[j]
            =Array[i];
                        Array[i]
            =tmp;
                    }
                }
                
            //exchange A[i],pivot
                tmp=Array[left];
                Array[left]
            =Array[i];
                Array[i]
            =tmp;
                
            return i;
            }
            void K_Big(double* Array,int left,int right,int k,double *dest)//
            {
                
            if (k<=0)
                {
                    
            return;
                }
                
            if (right-left+1<=k)
                {
                    memcpy(dest,
            &Array[left],sizeof(double)*(right-left+1));
                    
            return;
                }
                
            int p=Partition(Array,left,right);
                
            int right_ele_num=right-p;
                
            if (right_ele_num>=k)//取右邊的前k個
                {
                    K_Big(Array,p
            +1,right,k,dest);
                }
                
            else{
                    
            //取左邊的k-right_ele_num-1個,加上中間一個,再加上右邊的right_ele_num個
                    right_ele_num++;//把中間的一個也加進(jìn)來了。
                    memcpy(&dest[k-right_ele_num],&Array[p],right_ele_num*sizeof(double));
                    K_Big(Array,left,p
            -1,k-right_ele_num,dest);
                }
            }
            void main()
            {
                
            double A[]={8,4,3,2,6,13,5};
                
            int n=7;
                
            //MergeSort(&A[0],0,6);
                
            //QuickSort(A,0,6);
                
            //HeapSort(A,7);
                /*for (int i=0;i<n;i++)
                {
                    cout<<A[i]<<" ";
                }
            */
                
            double B[5];
                
            int k=5;
                K_Big(A,
            0,6,k,B);
                
            for (int i=0;i<k;i++)
                {
                    cout
            <<B[i]<<endl;
                }
                cout
            <<endl;
                delete A;
            }
            Homepage: http://www.zoumin.org/
            Posted on 2010-09-25 21:36 鄒敏 閱讀(250) 評論(0)  編輯 收藏 引用

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


            精品多毛少妇人妻AV免费久久| 亚洲欧美日韩久久精品| 国产精品美女久久久m| 丁香久久婷婷国产午夜视频| 91久久精品国产成人久久| 亚洲v国产v天堂a无码久久| 久久香蕉超碰97国产精品| 精品一久久香蕉国产线看播放| AV无码久久久久不卡蜜桃| 国产精品亚洲综合专区片高清久久久| 人妻无码精品久久亚瑟影视 | 偷偷做久久久久网站| 国产精品青草久久久久婷婷| 伊人久久大香线蕉综合热线| 国产精品一区二区久久| 国产成人精品综合久久久久| 久久国产午夜精品一区二区三区| 久久人人爽人人爽人人AV| 中文字幕久久亚洲一区| 99久久国产综合精品成人影院| 久久久久久亚洲AV无码专区| 久久精品综合网| 少妇被又大又粗又爽毛片久久黑人| 国产亚洲精久久久久久无码 | 久久免费小视频| 久久亚洲美女精品国产精品| 超级97碰碰碰碰久久久久最新| 久久99精品久久久久久齐齐| 久久综合狠狠综合久久激情 | 亚洲AV日韩AV天堂久久| 国产精品一区二区久久精品涩爱| 久久99热这里只有精品国产 | 狠狠干狠狠久久| A狠狠久久蜜臀婷色中文网| 伊人久久大香线蕉av一区| 久久精品亚洲AV久久久无码| 国产精品久久久久蜜芽| 久久香综合精品久久伊人| 无码人妻少妇久久中文字幕蜜桃| 国产精品成人久久久| 99蜜桃臀久久久欧美精品网站|