目录
题目
作者: Turbo时间限制: 1S章节: 课程设计
问题描述 :
在 「挑战赛」 开幕式的压轴节目 「无人机方阵」中,每一架无人机展示一种灯光颜色。 无人机方阵通过两种操作进行颜色图案变换:
(1) 调整无人机的位置布局
(2) 切换无人机展示的灯光颜色
给定两个大小均为 N*M 的二维数组 source 和 target 表示无人机方阵表演的两种颜色图案,由于无人机切换灯光颜色的耗能很大,请返回从 source 到 target 最少需要多少架无人机切换灯光颜色。
注意: 调整无人机的位置布局时无人机的位置可以随意变动。
示例 1:
输入:
2 2
1 3
5 4
3 1
6 5
输出:1
解释:
第一行输入2 2表示方阵为2行2列,后面跟着的两行为source,再两行为target。
最佳方案为
将 [0,1] 处的无人机移动至 [0,0] 处;
将 [0,0] 处的无人机移动至 [0,1] 处;
将 [1,0] 处的无人机移动至 [1,1] 处;
将 [1,1] 处的无人机移动至 [1,0] 处,其灯光颜色切换为颜色编号为 6 的灯光;
因此从source 到 target 所需要的最少灯光切换次数为 1。
示例 2:
输入:
2 3
1 2 3
3 4 5
1 3 5
2 3 4
输出:0
解释:
仅需调整无人机的位置布局,便可完成图案切换。因此不需要无人机切换颜色
输入说明 :
输入若干行:
第一行为两个整数n和m,n代表二维数组的行数,m代表二维数组的列数。
而后n行,每行输入m个整数,代表source数组的元素。
再n行,每行输入m个整数,代表target数组的元素。
提示:
1 <= n, m <=100
1 <= source[i][j], target[i][j] <=10^4
输出说明 :
输出一个整数表示结果。
输入范例
3 3
4 5 2
2 3 4
7 8 3
3 5 8
3 7 3
7 1 9输出范例
4
题目分析
本题实际上就是两个序列中的元素相互抵消,只要元素相同就能抵消一个,这样一来,可以运用vector中的find查找以及erase删除使相同的元素全部被抵消,随便一个序列剩下多少个元素(因为这两个序列剩下的元素数目一定是一样的)便是需要移动的步骤
解答
代码
#include "bits/stdc++.h"
using namespace std;
#define MVnum 100000
int main(){
int N,M;
cin>>N>>M;
multiset<int >arrr,arry;
for(int i=0;i<M*N;i++){
int k;
cin>>k;
arrr.insert(k);
}
for(int i=0;i<M*N;i++){
int k;
cin>>k;
arry.insert(k);
}
for(int i=0;i<M*N;i++){
if(arry.find(*arrr.begin())!=arry.end())//如果在第一个有序表中存在第二个有序表中的首个元素
arry.erase(arry.find(*arrr.begin()));//删除第一个有序表中的那个元素
arrr.erase(arrr.begin());//并且删除第二个有序表的首个元素
}
cout<<arry.size();//这样剩下的第一个序列中的元素就都是所求
return 0;
}
代码详解与难点分析(可无)
两个序列的输入自然不必说,关键在于后续的处理,
本题实际上就是两个序列中的元素相互抵消,只要元素相同就能抵消一个,这样一来,可以运用vector中的find查找以及erase删除使相同的元素全部被抵消,随便一个序列剩下多少个元素(因为这两个序列剩下的元素数目一定是一样的)便是需要移动的步骤
for(int i=0;i<M*N;i++){
if(arry.find(*arrr.begin())!=arry.end())//如果在第一个有序表中存在第二个有序表中的首个元素
arry.erase(arry.find(*arrr.begin()));//删除第一个有序表中的那个元素
arrr.erase(arrr.begin());//并且删除第二个有序表的首个元素
}
cout<<arry.size();//这样剩下的第一个序列中的元素就都是所求