算法提高 上帝造题五分钟(java)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/lc5801889/article/details/88559651

问题描述
  第一分钟,上帝说:要有题。于是就有了L,Y,M,C
  第二分钟,LYC说:要有向量。于是就有了长度为n写满随机整数的向量
  第三分钟,YUHCH说:要有查询。于是就有了Q个查询,查询向量的一段区间内元素的最小值
  第四分钟,MZC说:要有限。于是就有了数据范围
  第五分钟,CS说:要有做题的。说完众神一哄而散,留你来收拾此题
输入格式
  第一行两个正整数n和Q,表示向量长度和查询个数
  接下来一行n个整数,依次对应向量中元素:a[0],a[1],…,a[n-1]
  接下来Q行,每行两个正整数lo,hi,表示查询区间[lo, hi]中的最小值,即min(a[lo],a[lo+1],…,a[hi])。
输出格式
  共Q行,依次对应每个查询的结果,即向量在对应查询区间中的最小值。
样例输入

	7 4
	1 -1 -4 8 1 2 -7
	0 0
	1 3
	4 5
	0 6

样例输出

	1
	-4
	1
	-7

样例说明
  第一个查询[0,0]表示求min{a[0]}=min{1}=1
  第二个查询[1,3]表示求min{a[1],a[2],a[3]}=min{-1,-4,8}=-4
  第三个查询[4,5]表示求min{a[4],a[5]}=min{1,2}=1
  第四个查询[0,6]表示查询整个向量,求min{a[0…6]}=min{1,-1,-4,8,1,2,-7}=-7
数据规模和约定
  1<=n<=1984,1<=Q<=1988,向量中随机整数的绝对值不超过1,000
  解题思路
  本题主要考察对数组的运算以及排序,题目描述比较晦涩难懂,但其本质就是让求一个数组在指定范围内的最小值是多少,要注意需要对数据进行截取后再排序,否则会造成运算超时导致过不了后面几个测试用例。
  代码如下:

import java.util.Arrays;
import java.util.Scanner;

public class Main{
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int arr[] = new int[n];
		int time = sc.nextInt();
		for (int i = 0; i < arr.length; i++) {
			arr[i] = sc.nextInt();
		}
		for (int j = 0; j < time; j++) {
			int lo = sc.nextInt();
			int li = sc.nextInt();
			int arr1[] = new int[li-lo+1];
			for(int k=0;k<arr1.length;k++){//将指定范围内的数组赋给一个新的数组以减少运算耗时
				arr1[k]=arr[lo];
				lo+=1;
			}
			lo=0;
			Arrays.sort(arr1);//对数组进行排序进而取得最小值
			System.out.println(arr1[lo]);
		}
	}

}

猜你喜欢

转载自blog.csdn.net/lc5801889/article/details/88559651