算法题--排椅子(贪心)


题目链接

code

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

struct node{
    int indx;//用来存储数组下标
    int cnt;//用来计数
};

bool cmp(node a,node b){  //判断是否是数字最大的一个就是经过最多谈话人的道
    return a.cnt>b.cnt;
}
node row[2010],cow[2010];

bool cmp2(node a,node b){
    return a.indx<b.indx;//判断是否为下标最小的
}

int main(){
    int M,N,K,L,D;
    int O=0,I=0;
    cin>>M>>N>>K>>L>>D;
    for(int i=0;i<=N;i++){
        cow[i].indx=i;//将下标记录
    }
    for(int i=0;i<=M;i++){
        row[i].indx=i;
    }
    for(int i=0;i<D;i++){
        int x,y,p,q;
        cin>>x>>y>>p>>q;//输入点
        if(y==q){
           row[min(x,p)].cnt++; //如果同 row
        }
        if(x==p){
            cow[min(y,q)].cnt++; //如果同cow
        }
    }
    sort(cow,cow+N+1,cmp); //排序
    sort(row,row+M+1,cmp);
    sort(row,row+K,cmp2); //对下标排序否则只有%10因为要输出下标最小而且穿过人最多的道的位置
    sort(cow,cow+L,cmp2);
    
    for(int i=0;i<K;i++){
        cout<<row[i].indx<<" "; //输出y
    }
    cout<<"\n";
    for(int i=0;i<L;i++){
        cout<<cow[i].indx<<" "; //输出x
    }
}

下面我对其进行详细讲:

这个C++程序是一个非常特定的问题的解决方案。代码逻辑主要涉及一些数组操作和排序,下面我会逐步解释代码的各个部分。

  1. 结构体 node:

    • indx:用于存储数组的索引。
    • cnt:用于计数。这个结构体似乎被用来跟踪行和列的状态。
  2. 函数 cmp(node a, node b):

    • 这是一个比较函数,用于比较两个 node 对象的 cnt 字段。如果 a.cnt 大于 b.cnt,则返回 true。这个函数在后面的排序操作中用到,似乎是为了根据某个"计数"来对数组进行排序。
  3. 数组 row 和 cow:

    • 这两个数组存储了2010个 node 对象,分别命名为 row[i]cow[i]。它们被初始化为它们的索引值,即 i
  4. 函数 cmp2(node a, node b):

    • 这是另一个比较函数,用于比较两个 node 对象的 indx 字段。如果 a.indx 小于 b.indx,则返回 true。这个函数在后面的排序操作中用到,似乎是为了根据某个"索引"来对数组进行排序。
  5. 主函数 main():

    • 首先,输入五个整数:M, N, K, L, D。
    • 然后,对 cowrow 数组进行初始化,将它们的索引值设为它们各自的索引。
    • 接着,进行 D 次循环,每次循环读取四个整数 x, y, p, q。如果 y 和 q 相等,或者 x 和 p 相等,那么对应的计数就会增加。
    • 然后,对 cowrow 数组按照前面提到的比较函数进行排序。
    • 接着,对 row 数组的前 K 个元素和 cow 数组的前 L 个元素进行索引排序(由 cmp2 比较函数决定)。
    • 最后,输出排序后的 rowcow 数组的前 K 和 L 个元素的索引。
相关推荐
星星202515 小时前
VSCode插件精选:4款高效UML绘图工具
笔记
大胆飞猪16 小时前
递归、剪枝、回溯算法---全排列、子集问题(力扣.46,78)
算法·leetcode·剪枝
Kisorge18 小时前
【电机控制】基于STM32F103C8T6的二轮平衡车设计——LQR线性二次线控制器(算法篇)
stm32·嵌入式硬件·算法
铭哥的编程日记19 小时前
深入浅出蓝桥杯:算法基础概念与实战应用(二)基础算法(下)
算法·职场和发展·蓝桥杯
Swift社区19 小时前
LeetCode 421 - 数组中两个数的最大异或值
算法·leetcode·职场和发展
cici1587419 小时前
基于高光谱成像和偏最小二乘法(PLS)的苹果糖度检测MATLAB实现
算法·matlab·最小二乘法
_OP_CHEN20 小时前
Linux网络编程:(八)GCC/G++ 编译器完全指南:从编译原理到实战优化,手把手教你玩转 C/C++ 编译
linux·运维·c++·编译和链接·gcc/g++·编译优化·静态链接与动态链接
lkbhua莱克瓦2420 小时前
Java基础——方法
java·开发语言·笔记·github·学习方法
StarPrayers.20 小时前
自蒸馏学习方法
人工智能·算法·学习方法
大锦终20 小时前
【动规】背包问题
c++·算法·动态规划