同時尋找最大數和最小數的最優算法 第二大數

我們知道,在一個容量為n的數據集合中尋找一個最大數,不管用什么樣的比較算法,至少要比較n-1次,就算是用競標賽排序也得比較n-1次,否則你找到的就不能保證是最大的數。那么,在一個容量為n的數據集合中同時尋找最大數和最小數的最小比較次數是多少呢?
???? 從一個容量為n的數據集合中同時找到最大數和最小數的最優方法是:首先讓所有的元素參與兩兩比較,這樣總共比較了n/2次,最大數肯定在勝者組中,最小數肯定在敗者組中;然后從容量為n/2的勝者組中找到最大的數,最少要比較n/2 - 1次;同理,從容量為n/2的敗者組中找到最小的數,最少要比較n/2 - 1次。所以總共需要比較 (3n/2) - 2次。以上假設n為偶數。奇數同理。

這是同時尋找最大數和最小數的最優算法

?

??? 那么,我們要從一個容量為n的數據集(假設該數據集是一個集合,即沒有相同的元素)中找到第二大元素需要多少次比較呢?
??? 一種習慣的方法是:先找出最大的元素,這需要比較n-1次;然后從剩下的n-1個元素中找到最大的,這個元素就是我們要找的第二大元素,這需要比較n-2次。做一總共比較2n-3次。
但是,
??? 還有一個更優的方法:
(1) 我們考慮淘汰賽的比較法,淘汰賽結束后,找出冠軍我們需要n-1次比較;如下圖所示,找到12需要比較7次。
(2) 此時我們要考慮到,亞軍應該存在于敗給冠軍的這些選手中(否則,每個元素都至少有兩個元素比它大),由于與冠軍比過的元素個數為┌log2n┐,從這些元素中找到最大值需要比較┌log2n┐ - 1次;如下圖所示,亞軍應該在10,11,4這三個元素中。否則,如果亞軍是5,那么冠軍12比它大,與它比較過的10也比它大,至少兩個元素大于5,所以5肯定不是亞軍的候選者。

?


(3)從而找出亞軍要比較n-1+┌log2n┐-1 = n-2+┌log2n次比較。這個算法是尋找亞軍的最優算法





分治與遞歸——最大值和次大值的最優算法


問題描述:輸入n個數,最壞情況下用?n + logn - 2?次比較找出當中的最大值和次大值。

算法思想:根據題意出現logn,則肯定用到二分或者堆的思路,但是輸入的數沒有經過排序,而且題目要求的計算量也不允許排序。這樣,就肯定會用到類似堆的思路,但是直接構造堆等同于排序。堆的思想跟競標賽類似,都是父節點>=<=)子節點。如果父節點都是從子節點而來,這樣就是競標賽;如果不是,這樣就是堆。既然不能排序又不能構造堆,那就只能用競標賽的思想,通過二分來進行最多logn次競賽,選出最大值(冠軍),而次大值(亞軍)只能在與最大值的比較中被淘汰(亞軍的實力只可能輸給冠軍),故在所有被最大值(冠軍)淘汰的數值中選取次大值,最多也是logn次比較,滿足題意(由于題意只限制了比較次數,故實現過程并沒有考慮時間復雜度和空間復雜度)

代碼實現:

//最大值和次大值的最優算法,數組中可能存在重復元素,不能處理最大值是0的情況

#include <stdio.h>

#define N 1000

int m[2*N];

int num[2*N];

int biaoji[N];

int bigger(int i)

{

????if(num[i]>num[i+1])

????{

????????biaoji[m[i+1]]=num[i];

????????return i;

????}

????else

????{

????????biaoji[m[i]]=num[i+1];

????????return i+1;

????}

}

int work(int a,int b)

{

????int i,j;

????while(a<b)

????{

????????for(i=a;i<b;i+=2)

????????{

????????????j=bigger(i);

????????????num[i/2]=num[j];

????????????m[i/2]=m[j];

????????}

????????if(i==b)

????????{

????????????num[i/2]=num[i];

????????????m[i/2]=m[i];

????????}

????????a=a/2;

????????b=b/2;

????}

????return num[a];

}

int work2(int l,int max)

{

????int i,flag=1;

????int bmax;

????for(i=l;i<2*l;++i)

????{

????????if(biaoji[i-l]==max)

????????{

????????????if(flag)

????????????{

????????????????flag=0;

????????????????bmax=num[i];

????????????}

????????????else if(bmax<num[i])

????????????????bmax=num[i];

????????}

????}

????return bmax;

}

int main()

{

????int i,l;

????int max,bmax;

????int f,start;

????while(true)

????{

????????printf("please putin the length:\n");

????????scanf("%d",&l);

????????if(l==0)

????????????break;

????????printf("please putin num[]:\n");

????????for(i=l;i<2*l;++i)

????????????scanf("%d",&num[i]);

????????for(i=l;i<2*l;++i)

????????????m[i]=(i-l);

????????max=work(l,2*l-1);

????????bmax=work2(l,max);

????????printf("the max is %d and the bmax is %d\n",max,bmax);

????}

?

????return 0;

}


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/449328.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/449328.shtml
英文地址,請注明出處:http://en.pswp.cn/news/449328.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

淺談mpvue項目目錄和文件結構

2019獨角獸企業重金招聘Python工程師標準>>> 在Visual Studio Code里面打開項目文件夾&#xff0c;我們可以看到類似如下的文件結構&#xff1a; 1、package.json文件 package.json是項目的主配置文件&#xff0c;里面包含了mpvue項目的基本描述信息、項目所依賴的各…

[AHOI2009]最小割(最大流+tarjan)

繼續填坑了&#xff0c;啦啦啦 這道題本來是準備枚舉每個邊&#xff0c;暫時去除它&#xff0c;但發現時間會爆炸的 于是決定另辟蹊徑 于是這篇題解就應運而生 首先還是網絡流跑一邊 畢竟題目叫最小割嘛&#xff0c;給個面子 然后跑一邊tarjan對滿流的邊處理掉&#xff0c;即不…

進程間通信---信號

什么是信號&#xff1f; 】 信號處理流程 信號類型 發送信號的函數 參數sig&#xff1a;代表 信號 接收信號的函數 參數 handle 的處理方式有幾種&#xff1f; 實例代碼 實例邏輯 圖中的等待操作使用&#xff1a;pause&#xff08;&#xff09;函數 代碼 在這里插入代碼片…

大白話解說,半分鐘就懂 --- 分布式與集群是什么 ? 區別是什么?

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 PS&#xff1a;這篇文章算是筆記&#xff0c;僅部分文字是原創&#xff0c;相當內容只是收集、整理、提煉、總結別人寫的。 沒有標為原創…

國信證券學習系列(6)

行業輪動策略&#xff1a; 本策略每隔1個月定時觸發計算1000能源&#xff08;399381.SZ&#xff09;、1000材料&#xff08;399382.SZ&#xff09;、1000工業&#xff08;399383.SZ&#xff09;、1000可選&#xff08;399384.SZ&#xff09;、1000消費&#xff08;399385.SZ&a…

用Linux命令行修圖——縮放、編輯、轉換格式——一切皆有可能

本文由 極客范 - 八卦愛好者 翻譯自 How-To Geek。歡迎加入極客翻譯小組&#xff0c;同我們一道翻譯與分享。轉載請參見文章末尾處的要求。ImageMagick是一系列的用于修改、加工圖像的命令行工具。ImageMagick能夠快速地使用命令行對圖片進行操作&#xff0c;對大量的圖片進行…

劍指offer:二維數組中的查找

目錄 題目解題思路具體代碼題目 題目鏈接劍指offer&#xff1a;二維數組中的查找題目描述 在一個二維數組中&#xff08;每個一維數組的長度相同&#xff09;&#xff0c;每一行都按照從左到右遞增的順序排序&#xff0c;每一列都按照從上到下遞增的順序排序。請完成一個函數&a…

函數對象 函數嵌套 名稱空間與作用域

函數對象&#xff1a; 函數是第一類對象&#xff0c;即函數可以當做數據傳遞 1 可以被引用 2 可以當做參數傳遞 3 返回值可以是函數 &#xff08;函數名 不帶&#xff08;&#xff09; 就是函數名的內存地址&#xff0c;帶括號就是執行函數&#xff09; 4 可以當做容器類型的…

國信證券學習系列(7)

跨品種套利策略&#xff1a; 本策略根據計算滾動的.過去的30個bar的均值正負0.5個標準差得到布林線 并在最新價差上穿上軌來做空價差,下穿下軌來做多價差 并在回歸至上下軌水平內的時候平倉 獲取數據&#xff1a; # 獲取兩個品種的收盤價時間序列closesContextInfo.get_ma…

dubbo-admin管理平臺搭建

一、前言 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 dubbo的使用&#xff0c;其實只需要有注冊中心&#xff0c;消費者&#xff0c;提供者這三個就可以使用了&#xff0c;但是并不能…

不朽傳奇-云計算技術背后的那些天才程序員:Qemu的作者法布里斯貝拉

作者&#xff1a;Liu Guo Hui&#xff0c;OpenStack中國社區&#xff0c;轉載請注明出處 眾所周知&#xff0c;虛擬化技術是構建云基礎架構不可或缺的關鍵技術之一&#xff0c;而在眾多虛擬化技術實現當中&#xff0c;KVM&#xff08;Kernel Virtual Machine&#xff09;因為L…

C學習筆記-字符串

對于C語言來說&#xff0c;字符串其實就是最后一個元素為’\0’的char數組 字符數組的初始化 字符數組常見的有兩種初始化方式 char str[] "hello";或者 char str[] {h, e, l, l, o};當使用sizeof&#xff08;str&#xff09;時&#xff0c;得到的大小為6&#xff…

Shiro安全框架入門篇(登錄驗證實例詳解與源碼)

一、Shiro框架簡單介紹 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Apache Shiro是Java的一個安全框架&#xff0c;旨在簡化身份驗證和授權。Shiro在JavaSE和JavaEE項目中都可以使用…

國信證券學習系列(8)

我為什么要用國信&#xff0c;就是這個原因&#xff0c;可以做期權&#xff0c;期貨&#xff0c;股票&#xff0c;etf&#xff0c;可轉債的回測。滿足了我所有的需要&#xff0c;我要做指數增強。通常的做法是股票和期貨。但實際上&#xff0c;股票和期權做組合&#xff0c;成本…

Socket程序從Windows移植到Linux下的一些注意事項

關于這個話題網上流傳的是一個相同的版本&#xff0c;就是那個第一項是頭文件的區別&#xff0c;但后面列出的頭文件只有#include沒有&#xff08;估計是原版的在不斷轉載的過程中有人不小心忘了把尖括號轉義&#xff0c;讓瀏覽器當html標記解析沒了&#xff09;的那個。現在整…

邊緣控制平面Ambassador全解讀

Ambassador是由Datawire開源的一個API網關項目&#xff0c;主要在Kubernetes的容器編排框架中使用。Ambassador本質上是一個通過配置邊緣/API來管理Envoy數據面板的控制面板。而Envoy則是一個基于第7層協議的網絡代理和通信總線&#xff0c;它是一個由Lyft開源的云原生服務&…

Linux 文件編輯命令 詳細整理

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 一、vi編輯器有3種基本工作模式 首先需要知道vi編輯器有3種基本工作模式&#xff0c;分別是&#xff1a;命令模式、文本輸入模式、和末…

專訪迅雷首席工程師:迅雷的下一代互聯網底層技術構想

摘要&#xff1a;互聯網合縱連橫頻頻上演&#xff0c;迅雷與小米的聯姻也成為了熱點&#xff0c;有許多人為迅雷的上市和迅雷的未來擔憂&#xff0c;這家像工程師一樣的公司&#xff0c;命運會怎樣&#xff0c;他們未來會如何走下去&#xff1f;對此CSDN專訪了迅雷首席工程師劉…

YASnippet - emacs 的代碼片段管理工具

添加 snippet M-x 然后輸入 yas-new-snippet 回車 RET&#xff0c;會出現一個新的 buffer # -*- mode: snippet -*-# name: # key: # --在出現的 buffer 中填寫相應的數據 # -*- mode: snippet -*-# name: vard# key: vard# --echo <pre>;var_dump($0);die;c-x c…

深入vuex原理(上)

前言 vuex作為vue生態的重要組成部分&#xff0c;是對store進行管理的一柄利劍。簡而言之&#xff0c;vuex是vue的狀態管理器。使用vuex可用使數據流變得清晰、可追蹤、可預測&#xff0c;更可以簡單的實現 類似時光穿梭 等高級功能&#xff0c;對于復雜的大型應用來講&#xf…