❗️点击这里提交测试
❤️对于答案之书中的答案:
用map<string, int>m来记录每个答案在答案之书中的位置;
用map<string, vector>z, f分别来记录正向和负向 每个缩写对应的所有答案。
❤️对于每个咨询的用户:
名字n1和n2,对应缩写s1和s2;
对s1+s2和s2+s1分别到z和f中查询所有答案:
①如果z中有正向答案,则利用i和j分别遍历z[s1+s2]和z[s2+s1]:
▶️如果i和j没有遍历完, i元素位置(m[元素])小于j元素位置 或 j已遍历完,则i++,否则j++;
⏹遍历到第k个答案则输出,结束遍历;
(坑:如果s1==s2,只需要遍历一个)
②如果没有正向答案,f中有负向答案,则同理遍历f;
③否则天机不可泄露。
一百行代码,写的有点乱,我就不放了😂小伙伴儿们可以自己根据思路实现