藍橋杯 演算法訓練 區間k大數查詢 (Java解題)

mcp3128發表於2018-01-17
問題描述

給定一個序列,每次詢問序列中第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


程式碼:

import java.lang.reflect.Array;
import java.util.Arrays;
import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		int n;
		Scanner x = new Scanner(System.in);
		n = x.nextInt();
		int s[] = new int[n + 1];//序列中整數
		int t[] = new int[n + 1];//進行排序互換操作的整數

		for (int i = 1; i <= n; i++) {
			s[i] = x.nextInt();
		}
		
		int m = x.nextInt();
		int s1[] = new int[m];// 儲存最後結果
		int l, r, k, d = 0, tt;
		for (int i = 1; i <= m; i++) {
			
			for (int j = 1; j <= n; j++)
				t[j] = s[j];//將s陣列的值賦給t,對t陣列進行操作

			l = x.nextInt();
			r = x.nextInt();
			k = x.nextInt();
			for (int p = l; p <= r; p++) {//排序
				for (int q = l; q <= r - 1; q++) {
					if (t[q] < t[q + 1]) {
						tt = t[q];
						t[q] = t[q + 1];
						t[q + 1] = tt;
					}
				}
			}
			s1[d] = t[k + l - 1];
			d++;
		}
		for (int i = 0; i < d; i++)
			System.out.println(s1[i]);
	}

}


相關文章