IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【CF1557B】Moamen and k-subarrays -> 正文阅读

[数据结构与算法]【CF1557B】Moamen and k-subarrays

传送门

我的想法

以为只用统计连续多少段递增的序列就是最少需要的分类数

my Code

//
// Created by 009 on 2022/3/8.
//

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

int main() {
    int t;
    cin >> t;
    while(t--) {
        int n, k;
        cin >> n >> k;
        vector<int> v(n);
        for(int i = 0; i < n; i++) cin >> v[i];
        int count = 1;
        int pre = v[0];
        // 记录分段有多少个subarray是连续的
        for(int i = 1; i < n; i++) {
            if(pre > v[i]) count += 1;
            pre = v[i];
        }
        //cout << count << endl;
        if(count > k) cout << "NO" << endl;
        else cout << "YES" << endl;
    }
}

结果并不是这样子的
确实不行,因为中间的有序会涉及到交叉的部分,凉凉

正确analysis

需要先来一个辅助数组然后从小到大排序,然后记录原数组的value和index的map
遍历辅助数组找到原数组的位置,看看它后面紧跟着的是不是有序数组的下一个
若是的话可以继续往下
否则遍历辅助数组的下一个

ac code

//
// Created by 009 on 2022/3/8.
//

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

int main() {
    int t;
    cin >> t;
    while(t--) {
        int n, k;
        cin >> n >> k;
        // 补充最后一个位置,以防越界
        vector<int> v(n), copy(n);
        map<int, int> mp; // 记录原vector中value和index的关系
        for(int i = 0; i < n; i++) cin >> v[i], copy[i] = v[i], mp[v[i]] = i;
        // 对copy sort的一下
        sort(copy.begin(), copy.end());
        int count = 0;
        // 记录原分段中有多少个满足copy排好的位置
        for(int i = 0; i < n; i++) {
            count++;
            //找到原位置,看看后面有几个接的上
            //保证j + 1不越界
            for(int j = mp[copy[i]]; j < n - 1; j++) {
                // 若连续则继续往后
                if(copy[i + 1] == v[j + 1]) i++;
                // 否则继续遍历copy
                else break;
            }
        }
        //cout << count << endl;
        if(count > k) cout << "NO" << endl;
        else cout << "YES" << endl;
    }
}

总结

greedy + sorting
注意index的边界处理,小心越界
要知道是谁越界

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-03-10 22:50:47  更:2022-03-10 22:52:23 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 13:54:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码