文章目录
问题 A: ly的小迷弟
题目描述
众所周知ly虽然是个小胖子,但是长得还是很好看的,所以她有很多小迷弟(bu cun zai de),但是ly当然不是个只看颜值的人了,所以在她觉得颜值还可以的所有人里,把这些人选出来按照智商排序…
虽然wjw不是ly的小迷弟,但是wjw很想知道某个智商值在这群人里能排多少名,那么只能麻烦你帮他了
输入
第一行一个整数N表示有N个被选出来的小迷弟
第二行N个整数分别表示这N个小迷弟的智商
接下来若干行表示wjw的询问,每行一个智商值
输出
每行一个整数表示答案

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=1000005;
int a[N];
int main()//这题有点卡时间,用sort排序后,二分查找就能过
{
int T;
int n;
scanf("%d",&T);
a[0]=0;
for(int i=1;i<=T;i++){
scanf("%d",&a[i]);
}
sort(a,a+T+1);
while(~scanf("%d",&n)){
//二分查找
int low=0,hight=T;
while(low<=hight){
int mid=(low+hight)/2;
if(n>a[mid]){
low=mid+1;
}else if(n<a[mid]){
hight=mid-1;
}else if(n==a[mid]){
printf("%d\n",mid);
break;
}
}
}
return 0;
}
问题 B: ly的仓鼠
题目描述
上完体育课的ly很无聊,于是准备去蹭一蹭临床专业的课程,正好今天他们准备研究一些仓鼠的基因,由于操作有点出错…ly得到了一段很长很长的基因链(都是由小写字母构成),作为一个好奇心极强的人,ly有了一个问题,每次取两个区间,用这两个区间的DNA生产出来的仓鼠,会是两只一模一样的仓鼠吗?
显然小胖子ly光有好奇心并没有那个能力去得出结果…只会提问不会解答,所以又要麻烦你帮她了。
输入
第一行输入两个正整数n,q,分别代表DNA串的长度以及要询问的次数。
第二行一个字符串S,表示ly得到的DNA序列
下面q行每行输入四个整数l1,r1,l2,r2分别代表q次询问,对于每一次询问请你判断两个[l,r]区间的DNA是否相同。
输出
对于每一个询问 相同输出YES不相同输出NO
数据量较大,建议使用scanf,printf输入输出

#include<bits/stdc++.h>
using namespace std;
string s;
int T,n,l1,r1,l2,r2;
int main(){
//这道题的关键是注意输入数据的合法性,对数据进行判断
while(~scanf("%d%d",&T,&n)){
cin>>s;
for(int i=0;i<n;i++){
scanf("%d%d%d%d",&l1,&r1,&l2,&r2);
if(r1>T||r2>T){
//数据处理1,排查
printf("NO\n");
}
else if((r1-l1)!=(r2-l2))printf("NO\n");//数据处理2,长度不一致,排除
else {
string s1=s.substr(l1-1,r1-l1+1);
string s2=s.substr(l2-1,r2-l2+1);
if(s1==s2)printf("YES\n");
else printf("NO\n");
}
}
}
return 0;
}
问题 C: wjw的星期五
题目描述
wjw最近运气极其差,什么roll点1-100连着十次都是个位数啊,买个珍珠奶茶没有珍珠啊,吃方便面没有调料包啊…
迷信的wjw觉得,一定是因为这个月的13号正好是星期五,才会导致他的运气这么差。
现在他想知道,在某个年份中,有多少个月的13号是星期五,这样他才可以提前做好心理准备。
PS.已知1998年1月1日是星期四,输入的年份肯定大于或等于1998年。
输入
input
输入只有一行,表示年份(大于等于1998年)
输出
output
输出只有一行,表示这一年中有多少个月的13号是星期五

本文通过一系列问题介绍算法的应用,包括ly的小迷弟的智商排序、仓鼠基因匹配、星期五迷信、0-1背包问题、投资策略、图书排序、部分背包问题和汽车加油优化。这些问题涵盖了分治算法和背包问题的解决思路,旨在提升读者的算法理解和应用能力。
最低0.47元/天 解锁文章
4872

被折叠的 条评论
为什么被折叠?



