C语言实现 蓝桥杯 算法提高 上帝造题五分钟

试题 算法提高 上帝造题五分钟

                                                                                  蓝桥杯试题解答汇总链接

资源限制

       时间限制:1.0s 内存限制:256.0MB


问题描述

       第一分钟,上帝说:要有题。于是就有了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
代码
#include<stdio.h>
int min(int x,int y){//求最小值函数 
	if(x>y){
		return y;
	}
	return x;
}
int main(){
	int n,q;
	scanf("%d%d",&n,&q);
	int a[n],i,j,b[q][2];
	for(i=0;i<n;i++){
		scanf("%d",&a[i]);
	}
	for(i=0;i<q;i++){
		scanf("%d%d",&b[i][0],&b[i][1]);
	}
	for(i=0;i<q;i++){
		if(b[i][0]==b[i][1]){//只有一个数直接输出 
			printf("%d\n",a[b[i][1]]);
		}
		else{
			int t=min(a[b[i][0]],a[b[i][0]+1]);//先初始化t的值 
			for(j=b[i][0]+2;j<=b[i][1];j++){
				t=min(t,a[j]);//每次比较取最小 
			}
			printf("%d\n",t);
		}
	}
	return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Derrick-Xu

谢大哥打赏,我会继续努力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值