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++程序是一个非常特定的问题的解决方案。代码逻辑主要涉及一些数组操作和排序,下面我会逐步解释代码的各个部分。
-
结构体 node:
indx
:用于存储数组的索引。cnt
:用于计数。这个结构体似乎被用来跟踪行和列的状态。
-
函数 cmp(node a, node b):
- 这是一个比较函数,用于比较两个
node
对象的cnt
字段。如果a.cnt
大于b.cnt
,则返回true
。这个函数在后面的排序操作中用到,似乎是为了根据某个"计数"来对数组进行排序。
- 这是一个比较函数,用于比较两个
-
数组 row 和 cow:
- 这两个数组存储了2010个
node
对象,分别命名为row[i]
和cow[i]
。它们被初始化为它们的索引值,即i
。
- 这两个数组存储了2010个
-
函数 cmp2(node a, node b):
- 这是另一个比较函数,用于比较两个
node
对象的indx
字段。如果a.indx
小于b.indx
,则返回true
。这个函数在后面的排序操作中用到,似乎是为了根据某个"索引"来对数组进行排序。
- 这是另一个比较函数,用于比较两个
-
主函数 main():
- 首先,输入五个整数:M, N, K, L, D。
- 然后,对
cow
和row
数组进行初始化,将它们的索引值设为它们各自的索引。 - 接着,进行 D 次循环,每次循环读取四个整数 x, y, p, q。如果 y 和 q 相等,或者 x 和 p 相等,那么对应的计数就会增加。
- 然后,对
cow
和row
数组按照前面提到的比较函数进行排序。 - 接着,对
row
数组的前 K 个元素和cow
数组的前 L 个元素进行索引排序(由cmp2
比较函数决定)。 - 最后,输出排序后的
row
和cow
数组的前 K 和 L 个元素的索引。