麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

1045. 快速排序(25)

2019-11-11 06:08:35
字體:
來源:轉載
供稿:網友

著名的快速排序算法里有一個經典的劃分過程:我們通常采用某種方法取一個元素作為主元,通過交換,把比主元小的元素放到它的左邊,比主元大的元素放到它的右邊。 給定劃分后的N個互不相同的正整數的排列,請問有多少個元素可能是劃分前選取的主元?

例如給定N = 5, 排列是1、3、2、4、5。則:

1的左邊沒有元素,右邊的元素都比它大,所以它可能是主元; 盡管3的左邊元素都比它小,但是它右邊的2它小,所以它不能是主元; 盡管2的右邊元素都比它大,但其左邊的3比它大,所以它不能是主元; 類似原因,4和5都可能是主元。 因此,有3個元素可能是主元。

輸入格式:

輸入在第1行中給出一個正整數N(<= 105); 第2行是空格分隔的N個不同的正整數,每個數不超過109。

輸出格式:

在第1行中輸出有可能是主元的元素個數;在第2行中按遞增順序輸出這些元素,其間以1個空格分隔,行末不得有多余空格。

輸入樣例: 5 1 3 2 4 5 輸出樣例: 3 1 4 5

#include<cstdio>#include<algorithm>using namespace std;const int maxn=100010;const int INF=0x7fffffff;int a[maxn];int leftMax[maxn],rightMin[maxn];int ans[maxn],cnt=0;int main(){ int n; scanf("%d",&n); for(int i=0;i<n;i++){ scanf("%d",&a[i]); } leftMax[0]=-1; for(int i=1;i<n;i++){ leftMax[i]=max(leftMax[i-1],a[i-1]); } rightMin[n-1]=INF; for(int i=n-2;i>=0;i--){ rightMin[i]=min(rightMin[i+1],a[i+1]); } for(int i=0;i<n;i++){ if(a[i]>leftMax[i]&&a[i]<rightMin[i]){ ans[cnt++]=a[i]; } } sort(ans,ans+cnt); 法二:直接暴力,會超時

#include<cstdio>#include<algorithm>using namespace std;const int maxn=100010;int a[maxn],temp[maxn];int main(){ int n; scanf("%d",&n); for(int i=0;i<n;i++){ scanf("%d",&a[i]); } int cnt=0; for(int i=0;i<n;i++){ int j=i-1; bool flag=true; while(j<i&&j>=0){ if(a[j]>a[i]){ flag=false; break; } j--; } if(flag==true){ int k=i+1; while(k<n){ if(a[k]<a[i]){ flag=false; break; } k++; } } if(flag==true){ temp[cnt++]=a[i]; } } sort(temp,temp+cnt); printf("%d/n",cnt); for(int i=0;i<cnt;i++){ printf("%d",temp[i]); if(i<cnt-1) printf(" "); } printf("/n"); return 0; }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品久久国产精麻豆96堂 | 色综合久久久久久久粉嫩 | 免费观看三级毛片 | 久久久久久久久久久高潮一区二区 | 久草热久 | 欧美日韩在线视频一区 | 国产成人精品网站 | 精品亚洲午夜久久久久91 | 亚洲综合视频一区 | 日韩欧美激情视频 | 成人一区二区在线观看视频 | 91在线视频观看 | 古装三级在线观看 | 一级黄色在线免费观看 | 92精品国产自产在线 | av免费在线不卡 | 午夜影院a | 亚洲精品 在线播放 | 久久久久久久一区二区 | 精品久久久久久久久久 | 2021狠狠操 | 成人男女啪啪免费观看网站四虎 | 亚洲午夜久久久精品一区二区三区 | 欧美福利视频一区二区三区 | 国产一区二区三区在线免费 | 二区三区四区视频 | 私库av在线免费观看 | 免费毛片免费看 | 宅男噜噜噜66一区二区 | bt 自拍 另类 综合 欧美 | 蜜桃网在线观看 | 欧美激情猛片xxxⅹ大3 | 蜜桃传媒视频麻豆第一区免费观看 | 欧美日韩在线免费观看 | 黄色片免费看网站 | 久久网国产 | 成人做爽爽爽爽免费国产软件 | 亚洲电影在线观看高清免费 | 国产毛片网 | 色毛片| 国产亚洲网 |