变换队列c++

题目描述

班上的同学们每个人都有各自的学号d(1d100) ,每个同学的学号各不相同。

所以学号可以用来唯一标识班上的某个同学。

假设有个班有五名同学(学号分别为 12345 ),他们排了两次队,

第一次排队的顺序为 53124

第二次排队的顺序为24531

//那么,我们称第二次排队的顺序为第一次排队顺序的"变位"。

同学们位置的变换,称之为 第一次队列到第二次队列的"​映射​"。

这个例子中,可以看到, 5 号同学站到了 3 号位, 3 号同学站到了 4 号位, 1 号同学站到了 5 号位, 2 号同学站到了 1 号位, 4 号同学站到了 2 号位。

所以他们的"​映射关系 ​"为 34512

全班有 n 个同学排队两次, (1n100)

第一次同学们排队的顺序,由第一行输入决定,

第二次同学们排队的顺序,由第二行输入决定,

请输出 第一次队列 到 第二次队列 的 "映射关系"

输入格式

第一行,输入全班总人数 n

第二行,输入第一次排队 n 位学生的学号(学号 大于等于1,小于等于100)

第三行,输入第二次排队 n 位学生的学号(学号 大于等于1,小于等于100)

输入格式

第一次队列 到 第二次队列的 "映射关系"

Samples

输入数据 1

复制代码
8
28 35 11 87 34 1 98 10
10 1 34 98 87 35 28 11

Copy

输出数据 1

复制代码
7 6 8 5 3 2 4 1

Copy

提示

  1. 队列一和队列二长度一定相同。
  2. 第二次队列的同学顺序可能和第一次队列的同学顺序相同

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int a[105],b[105],n;
int main(){
	cin>>n;
	for(int i=1;i<=n;i++)cin>>a[i];
	for(int i=1;i<=n;i++)cin>>b[i];
	for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)if(b[j]==a[i])cout<<j<<' ';
	return 0;
}

复杂度 O()

相关推荐
Agent手记18 小时前
智能财务对账Agent如何设计?2026金融大模型Agent架构设计与实战指引
人工智能·算法·ai·金融
Emerson_202618 小时前
stack,queue,list的区别和联系
数据结构·c++·list·queue·stack
计算机安禾18 小时前
【算法分析与设计】第5篇:最大子数组问题:分治与线性扫描的对比分析
算法
王老师青少年编程18 小时前
2026年全国青少年信息素养大赛初赛真题(算法应用主题赛C++初中组初赛真题2:文末附答案和解析)
c++·真题·答案·初赛·2026年·初中组·青少年信息素养大
z2005093019 小时前
今日算法(组合问题)(回溯解法)
算法·深度优先
Shiy_19 小时前
用 TypeScript 验证三门问题:为什么换门胜率是 2/3?
算法·typescript
Yunzenn19 小时前
深度解析字节最新研究-Cola DLM 第 06 章:分块因果 DiT 先验 —— 在隐空间里做 Flow Matching
人工智能·算法·架构
HjhIron19 小时前
数组去重:从零开始,写一个靠谱的工具函数
算法·面试
阿黎梨梨19 小时前
#动态规划入门:从“爬楼梯”问题理解核心思想
算法
黎阳之光19 小时前
技术赋能智慧新能源|黎阳之光风电叶片光栅载荷+声纹AI智能监测技术落地应用
大数据·人工智能·物联网·算法·安全