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

E. Correct Placement

题目链接:Problem - E - Codeforces

题目大意:有n个高为hi,宽为wi的(1<= i <= n)的矩形,判断是否矩形 i 可以包含  矩形 j。即满足:

  • hj < hi 且 wj < wi 
  • wj < hi  hj < wi   

满足以上之一即可,然后将下标 j 写在 下标 i 上的对应数组。

数据范围:

第一行包含一个整数 t ( 1 ≤ t ≤ 1e4 )--测试用例数。

每个测试用例的第一行包含一个整数 n ( 1 ≤ n ≤ 2⋅1e5 ) -数量。

随后是 n 行,两个整数 hi 和 wi 描述。( 1≤hi, wi ≤ 1e9 )--分别是 i 的高度和宽度。

保证所有测试用例的 n 之和不超过 2⋅1e5 。

考察:双指针, 排序, 贪心

解题思路:首先,根据满足的条件可以看出,矩形可以横着放,竖着放。所以每一个矩形可以维护,最大值为高。然后通过高进行排序, 核心:贪心的想法, 最小的矩形最有可能满足,后面的大矩形匹配, 所以采用双指针技巧,维护一个最小的矩形即可。在高度满足的情况下,即通过比较矩形的宽度,维护最小矩形。   注意:代码中 pos1 指向的是p数组的下标, pos是输入时的下标。

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

using i64 = long long;
using i128 = __int128;

void solve(){
    int n;
    cin >> n;
    vector<int> a(n+1), b(n+1);
    vector<array<int, 3>> p;
    for(int i=1; i<=n; i++) {
        cin >> a[i] >> b[i];
        if(a[i]<b[i]){
            swap(a[i],b[i]);
        }
        p.push_back({a[i],b[i],i});
    }    
    //排序
    sort(p.begin(), p.end(),[&](auto&x, auto&y){
        if(x[0] < y[0] || x[0] > y[0]){
            return x[0] < y[0];
        }else if(x[0]==y[0]) {
            return x[1] < y[1];
        }
    });
    vector<int> ans(n+1,-1);
    
    int i=0,j=0;
    int pos = -1;//p数组的下标
    int pos1 = -1;//原输入的下标
    while(i<n) {
        while(pos==-1 || (j<n && p[i][0] > p[j][0])) {
            if(pos==-1 || p[pos][1] > p[j][1]) {//维护最小的矩形
                pos1 = p[j][2];
                pos = j;
            }
            j++;
        }
        //判断是否可以更新
        if(pos==-1 || (a[p[i][2]] > a[pos1] && b[p[i][2]] > b[pos1])) {
            ans[p[i][2]] = pos1;
        }
        i++;
    }
    for(int i=1; i<=n; i++) {
        cout << ans[i] << " ";
    }
    cout << "\n";
}

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0),cout.tie(0);
    int t = 1;
    cin >> t;
    while(t--) {
        solve();
    }
}

感谢收看与点赞, 欢迎大佬指正。


http://www.kler.cn/a/526150.html

相关文章:

  • Addressable学习
  • .Net / C# 繁体中文 与 简体中文 互相转换, 支持地方特色词汇
  • Leetcode刷题-不定长滑动窗口
  • Rust:Rhai脚本编程示例
  • [STM32 - 野火] - - - 固件库学习笔记 - - -十三.高级定时器
  • Spring MVC 综合案例
  • 单词翻转(信息学奥赛一本通1144)
  • SpringBoot 原理分析
  • 智慧园区管理系统为企业提供高效运作与风险控制的智能化解决方案
  • 园区管理智能化创新引领企业效能提升与风险控制新趋势
  • LabVIEW微位移平台位移控制系统
  • 【hot100】刷题记录(7)-除自身数组以外的乘积
  • 如何构建树状的思维棱镜认知框架
  • 为什么“记住密码”适合持久化?
  • 架构知识整理与思考(其四)
  • 从零搭建一个Vue3 + Typescript的脚手架——day3
  • LeetCode:63. 不同路径 II
  • 在K8s中部署动态nfs存储provisioner
  • 基于 Redis GEO 实现条件分页查询用户附近的场馆列表
  • React第二十八章(css modules)
  • 在彼此的根系里呼吸
  • OpenEuler学习笔记(十七):OpenEuler搭建Redis高可用生产环境
  • V103开发笔记1-20250113
  • 类文件结构
  • Baklib如何提升企业知识管理效率与市场竞争力的五大对比分析
  • FFmpeg rtmp推流直播