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

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

算法訓練 區間k大數查詢

2019-11-11 07:24:03
字體:
來源:轉載
供稿:網友

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

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

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

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

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

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

對于100%的數據,n,m<=1000;

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

package 區間k大數查詢;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(); }}

這里寫圖片描述


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 琼结县| 齐齐哈尔市| 浏阳市| 平阴县| 巴里| 石楼县| 甘泉县| 东乌珠穆沁旗| 周至县| 滨海县| 郴州市| 邵阳县| 通辽市| 垦利县| 鄂托克前旗| 隆尧县| 忻城县| 大名县| 冕宁县| 博罗县| 新和县| 雅江县| 墨脱县| 汉沽区| 兴和县| 靖远县| 日照市| 秦安县| 湟源县| 鸡西市| 潞城市| 炎陵县| 忻州市| 陆川县| 东乡族自治县| 邛崃市| 合水县| 开鲁县| 忻州市| 肥乡县| 新丰县|