国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

算法訓(xùn)練 區(qū)間k大數(shù)查詢

2019-11-14 09:42:05
字體:
供稿:網(wǎng)友

問題描述 給定一個序列,每次詢問序列中第l個數(shù)到第r個數(shù)中第K大的數(shù)是哪個。

輸入格式 第一行包含一個數(shù)n,表示序列長度。

第二行包含n個正整數(shù),表示給定的序列。

第三個包含一個正整數(shù)m,表示詢問個數(shù)。

接下來m行,每行三個數(shù)l,r,K,表示詢問序列從左往右第l個數(shù)到第r個數(shù)中,從大往小第K大的數(shù)是哪個。序列元素從1開始標號。

輸出格式 總共輸出m行,每行一個數(shù),表示詢問的答案。 樣例輸入 5 1 2 3 4 5 2 1 5 2 2 3 2 樣例輸出 4 2 數(shù)據(jù)規(guī)模與約定 對于30%的數(shù)據(jù),n,m<=100;

對于100%的數(shù)據(jù),n,m<=1000;

保證k<=(r-l+1),序列中的數(shù)<=106。

package 區(qū)間k大數(shù)查詢;import java.util.Arrays;import java.util.Scanner;public class Main { public static int KSort(int[] num , int start ,int end ,int k){ int len =end - start + 1; int[] tmp = new int[len]; int cnt = 0; for ( int i = start-1 ; i <= end-1 ; i++){ tmp[cnt] = num[i]; cnt++; } Arrays.sort(tmp); return tmp[tmp.length-k]; } public static void main(String[] args) { // TODO Auto-generated method stub Scanner in = new Scanner(System.in); int n = in.nextInt(); int[] num = new int[n]; for ( int i = 0 ; i < n ; i++){ num[i] = in.nextInt(); } int times = in.nextInt(); for ( int i = 0 ; i < times ; i++){ int start = in.nextInt(); int end = in.nextInt(); int k = in.nextInt(); int k_max = KSort(num, start, end, k); System.out.PRintln(k_max); } in.close(); }}

這里寫圖片描述


上一篇:VC++簡單窗口

下一篇:【t085】Sramoc問題

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 兴安盟| 江孜县| 天峻县| 临猗县| 阜城县| 临泉县| 景谷| 元谋县| 谷城县| 马尔康县| 五大连池市| 荃湾区| 神池县| 疏附县| 德格县| 章丘市| 苏尼特右旗| 麦盖提县| 德昌县| 区。| 沙雅县| 新平| 二手房| 芮城县| 和硕县| 江阴市| 横峰县| 揭东县| 绵竹市| 邻水| 桃源县| 郑州市| 阿拉善盟| 喀喇| 济阳县| 古蔺县| 荆门市| 安仁县| 崇仁县| 东宁县| 湘阴县|