P2251 质量检测
题面
为了检测生产流水线上总共 件产品的质量,我们首先给每一件产品打一个分数 表示其品质,然后统计前 件产品中质量最差的产品的分值 ,以及第 2 至第 件的 ... 最后统计第 至第 件的 。根据 再做进一步评估。
请你尽快求出 序列。
输入格式
输入共两行。
第一行共两个数 、,由空格隔开。含义如前述。
第二行共 个数,表示 件产品的质量。
输出格式
输出共 行。
第 1 至 行每行一个数,第 行的数 。含义如前述。
数据范围
30%的数据,
100%的数据,
100%的数据,
思路
这是一道ST表水题。想必不要多说。
代码
#include <bits/stdc++.h>
using namespace std;
int STTable[100005][25];
int min(int x, int y){
if(x>y){
return y;
}
else{
return x;
}
}
inline int read() {
int x=0,f=1;
char ch=getchar();
while (ch<'0'||ch>'9') {
if (ch=='-') f=-1;
ch=getchar();
}
while (ch>='0'&&ch<='9') {
x=x*10+ch-48;
ch=getchar();
}
return x*f;
}
int query(int l,int r) {
int k=log2(r-l+1);
return min(STTable[l][k],STTable[r-(1<<k)+1][k]);
}
int main() {
int N=read(),M=read();
for(int i=1; i<=N; i++) {
STTable[i][0] = read();
}
for(int j=1; j<=21; j++) {
for(int i=1; i+(1<<j)-1<=N; i++) {
STTable[i][j]=min(STTable[i][j-1],STTable[i+(1<<(j-1))][j-1]);
}
}
for(int l=1,r=M;r<=N;l++,r++){
cout<<query(l,r)<<endl;
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律