当前位置: 首页 > article >正文

AcWing 3817:数组 ← 贪心算法

【题目来源】
https://www.acwing.com/problem/content/3820/

【题目描述】
给定一个长度为 nA 的非降序整数数组 A 和一个长度为 nB 的非降序整数数组 B。
请问,能否从 A 中挑选 k 个数,从 B 中挑选 m 个数,使得在 A 中挑选出的任何数都严格小于在 B 中挑选出的任何数。

【输入格式】
第一行包含两个整数 nA,nB。
第二行包含两个整数 k,m。
第三行包含 nA 个整数 a1,a2,…,anA。
第四行包含 nB 个整数 b1,b2,…,bnB。

【输出格式】
共一行,能则输出 YES,否则输出 NO。

【数据范围】
1≤nA,nB≤10^5,
1≤k≤nA,
1≤m≤nB,
−10^9≤ai,bi≤10^9。
保证 A 和 B 都是
非降序数组。

【输入样例1】
3 3
2 1
1 2 3
3 4 5

【输出样例1】
YES

【输入样例2】
3 3
3 3
1 2 3
3 4 5

【输出样例2】
NO

【输入样例3】
5 2
3 1
1 1 1 1 1
2 2

【输出样例3】
YES

【算法分析】
☆★ 贪心是通过局部最优解,找到全局最优解。所以,贪心算法一般适用于
单峰问题。
☆★ C++ 中
reverse() 函数的示例代码。

#include<bits/stdc++.h>
using namespace std;

const int maxn=1e5+5;
int a[maxn];

int main() {
    int n;
    cin>>n;
    
    for(int i=0; i<n; i++) cin>>a[i];
    reverse(a,a+n);
    for(int i=0; i<n; i++) cout<<a[i]<<" ";

    return 0;
}


/*
in:
5
1 3 5 7 9

out:
9 7 5 3 1
*/


【算法代码】

#include<bits/stdc++.h>
using namespace std;

const int maxn=1e5+5;
int a[maxn];
int b[maxn];

int main() {
    int na,nb,k,m;
    cin>>na>>nb>>k>>m;
    for(int i=0; i<na; i++) cin>>a[i];
    for(int i=0; i<nb; i++) cin>>b[i];

    reverse(b,b+nb);

    if(a[k-1]<b[m-1]) cout<<"YES";
    else cout<<"NO";

    return 0;
}


/*
in:
3 3
2 1
1 2 3
3 4 5

out:
YES
*/



【参考文献】
https://www.acwing.com/solution/content/120077/

 


http://www.kler.cn/news/355453.html

相关文章:

  • JavaWeb 23.NPM配置和使用
  • HTML5教程(四) - 结构标签
  • git+cmake将Open3D配置到visual studio
  • Android中 tools:text 和 android:text区别
  • Java JDK的面试题
  • Redis基础篇(含redis在linux环境下的安装教程,以及用docker安装redis的教程)
  • 【Linux驱动开发】嵌入式Linux驱动开发基本步骤,字符设备开发入门,点亮LED
  • Python知识梳理总结思维导图
  • SpringBoot实现的物流优化策略
  • 笔记整理—linux网络部分(2)Linux网络框架
  • 如何成为 Rust 核心贡献者?Rust 开发的核​​心是什么?Rust 重要技术专家揭秘
  • Redis登录校验
  • 在电脑上免费分区的 5 个有效磁盘分区软件工具
  • flume 负载均衡 详解
  • 2024年电子信息与信号处理国际学术研讨会(EISP 2024,2024年11月15-17日)
  • JavaWeb合集15-Apache POI
  • 需要补充的技能
  • WPF常见容器全方位介绍
  • TS项目中如何合理的为接口定义参数类型
  • C++贪心算法