关注
贪心
可以通过有限次的分组和重排,使得书籍编号有序。
首先,需要将书籍按照编号从小到大排序,同时记录每本书原来的位置。
排序后,遍历排序后的数组,检查相邻两本书的原始位置是否连续。如果不连续,说明这里必须要进行一次分组。
统计需要分组的次数,如果这个次数不超过给定的 ,那么就可以实现目标。
#include <iostream>
(30316)#include <vector>
#include <algorithm>
using namespace std;
void solve() {
int n, k;
cin >> n >> k;
vector<pair<long long, int>> books(n);
for (int i = 0; i < n; i++) {
cin >> books[i].first;
books[i].second = i;
}
// 按编号排序
sort(books.begin(), books.end());
int groups = 1;
for (int i = 1; i < n; i++) {
// 如果相邻两本书的原始位置不连续,需要增加一个分组
if (books[i].second - books[i-1].second != 1) {
groups++;
}
}
// 如果需要的分组数不超过k,则可以实现目标
cout << (groups <= k ? "True" : "False") << endl;
}
int main() {
int t;
cin >> t;
while (t--) {
solve();
}
return 0;
}
查看原帖
3 4
相关推荐
点赞 评论 收藏
分享
01-30 22:03
门头沟学院 Java
用微笑面对困难:我滴妈,【俩月】【实习】【主管】仨debuff吃满了,独立设计开发的项目写了绝大占比的运营板块,你独立开发,那维护、问题复盘、日志更新、bug、策划书全是自己整的? 点赞 评论 收藏
分享
查看9道真题和解析 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 春招至今,你的战绩如何? #
1231次浏览 11人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
6558次浏览 34人参与
# MiniMax求职进展汇总 #
21863次浏览 278人参与
# 网易游戏笔试 #
6146次浏览 83人参与
# 把自己当AI,现在最消耗你token的问题是什么? #
6519次浏览 153人参与
# 职能管理面试记录 #
10478次浏览 59人参与
# 巨人网络春招 #
10939次浏览 197人参与
# 小红书求职进展汇总 #
226555次浏览 1354人参与
# 简历中的项目经历要怎么写? #
308782次浏览 4115人参与
# 你的房租占工资的比例是多少? #
92047次浏览 896人参与
# 腾讯音乐求职进展汇总 #
160156次浏览 1103人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
186008次浏览 1107人参与
# 正在春招的你,也参与了去年秋招吗? #
361950次浏览 2628人参与
# 机械求职避坑tips #
94318次浏览 567人参与
# 如何一边实习一边找下家? #
41025次浏览 352人参与
# 面试官最爱问的 AI 问题是...... #
25958次浏览 803人参与
# 现在入门AI应该走哪些方向? #
7978次浏览 146人参与
# 国企还是互联网,你怎么选? #
205420次浏览 1506人参与
# 你收到了哪些公司的笔试? #
28982次浏览 179人参与
# 校招笔试 #
463070次浏览 2944人参与
# 网易笔试 #
151611次浏览 789人参与
# 跟HR说什么能被秒回? #
14947次浏览 252人参与

