算法提高 上帝造题五分钟

举报
陈言必行 发表于 2021/08/14 01:04:27 2021/08/14
【摘要】 问题描述 第一分钟,上帝说:要有题。于是就有了L,Y,M,C   第二分钟,LYC说:要有向量。于是就有了长度为n写满随机整数的向量   第三分钟,YUHCH说:要有查询。于是就有了Q个查询,查询向量的一段区间内元素的最小值   第四分钟,MZC说:要有限。于是就有了数据范围   第五分钟,CS说:要有做题的。说完众神一哄而散,留你...

问题描述
第一分钟,上帝说:要有题。于是就有了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行,依次对应每个查询的结果,即向量在对应查询区间中的最小值。
样例输入
74
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

分析:此题的解题方式,也是区间K大数的模式,找的你的区间,找的最小的那个数就可以了。


      
  1. import java.util.Arrays;
  2. import java.util.Scanner;
  3. //上帝造题五分钟
  4. public class Main {
  5. public static void main(String[] args){
  6. // TODO Auto-generated methodstub
  7. Scanner sc=newScanner(System.in);
  8. int n=sc.nextInt();intm=sc.nextInt();
  9. int[] a=new int[n];
  10. for(int i=0;i
  11. a[i]=sc.nextInt();
  12. }
  13. int[][] b=newint[m][2];
  14. for(int i=0;i
  15. b[i][0]=sc.nextInt();
  16. b[i][1]=sc.nextInt();
  17. }
  18. for(int i=0;i
  19. System.out.println(f(a,b[i][0],b[i][1]));
  20. }}
  21. public static int f(int[]a,int r,int l){
  22. int[] b=new int[l-r+1];
  23. for(int i=0;i
  24. b[i]=a[r+i];
  25. }
  26. Arrays.sort(b);
  27. return b[0];
  28. }
  29. }


文章来源: czhenya.blog.csdn.net,作者:陈言必行,版权归原作者所有,如需转载,请联系作者。

原文链接:czhenya.blog.csdn.net/article/details/76092142

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。