【模拟】【codeforces】599B Spongebob and Joke

http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=282385

 

就是一个人最开始有一串数a1 a2 ... am

他的熊孩子队友用一组函数f1 f2 ... fn 以及bi = fai 把串A换成了串B

现在告诉你B和F,让你把A换回来,能换回来输出A,换回来可能有多重情况输出ambiguity,不可能换回来输出impossible

 

ai其实就是f的一个定位,给出一个f(x),求x

所以出现多解的情况就是对于一个b中的值,f有超过一个以上的位置上的值等于bi

出现不可能的情况就是对于一个bi,没有f中的值与之对应

 

因为最后输出的就是x这个位置,所以直接在输入的时候把f翻转一下,f[i]的值表示f在i这个值的时候的定位,之后直接输出即可 

 

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 
 4 int f[100005];
 5 int b[100005];
 6 int a[100005];
 7 int n, m;
 8 bool Ambiguity;
 9 bool Impossible;
10 bool ambi[100005];
11 
12 int main(){
13     while(~scanf("%d%d", &n, &m)){
14         Ambiguity = false;
15         Impossible = false;
16         memset(ambi, 0, sizeof(ambi));
17         memset(f, 0, sizeof(f));
18         memset(b, 0, sizeof(b));
19         memset(a, 0, sizeof(a));
20         for(int i = 1; i <= n; i++){
21             int pos;
22             scanf("%d", &pos);
23             if(f[pos] == 0) f[pos] = i;
24             else{
25                 ambi[pos] = true;
26             }
27         }
28         for(int i = 1; i <= m; i++){
29             scanf("%d", &b[i]);
30         }
31 
32         //solve()
33         for(int i = 1; i <= m; i++){
34             if(f[ b[i] ] != 0 && ambi[ b[i] ] != true) a[i] = f[ b[i] ];
35             else if(f[ b[i] ] == 0){
36                 Impossible = true;
37             }
38             else{
39                 Ambiguity = true;
40             }
41         }
42 
43         if(Impossible){
44             printf("Impossible\n");
45         }
46         else if(Ambiguity){
47             printf("Ambiguity\n");
48         }
49         else{
50             printf("Possible\n");
51             for(int i = 1; i<= m; i++){
52                 printf("%d", a[i]);
53                 if(i != m) printf(" ");
54             }
55             printf("\n");
56         }
57     }
58 
59     return 0;
60 }

 

转载于:https://www.cnblogs.com/miaowTracy/p/5336192.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/288427.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux磁盘第一个扇区分析,Linux磁盘分区

一、磁盘连接方式与设备文件名的关系计算机常见的磁盘接口有两种&#xff0c;分别是IDE与SATA接口&#xff0c;目前主流接口已经是SATA接口了。一个IDE扁平电缆可以连接两个IDE设备&#xff0c;通常主机又都会提供两个IDE接口&#xff0c;因此最多可以接到四个IDE设备。也就是说…

剑指offer之分行从上到下打印二叉树

1 题目 分行从上到下打印二叉树 23 5 1 4 2 3 我们打印如下 23 51 4 2 3 2 分析 之前这篇博客写了通过队列按层打印剑指offer之按层打印树节点 现在无非就是还要按照条件打印&#xff0c;第一次打印1个&#xff0c;然后第二次打印2个&…

转:char*, char[] ,CString, string的转换

转&#xff1a;char*, char[] ,CString, string的转换 (一) 概述string和CString均是字符串模板类&#xff0c;string为标准模板类&#xff08;STL&#xff09;定义的字符串类&#xff0c;已经纳入C标准之中&#xff1b;CString&#xff08;typedef CStringT > CString&am…

虚拟机VMware安装XP系统错误解决办法

虚拟机给我的编程工作确实带了很多方便&#xff0c;但是虚拟机的一个最大挑战是硬件赶不上&#xff0c;速度太慢了。最近一直在致力于虚拟机上Win7专业版平台上SQL Server 2005Visual Studio 2012系统开发&#xff0c;最初还可以&#xff0c;但是越到后面速度越慢。最后决定重新…

[TP5填坑]关于助手函数input一不小心取不到get值的解决办法

声明&#xff1a;适用于懒人 常规对于这个什么鬼取不到值我也是很绝望的&#xff0c;通常都是看一遍手册就开始写&#xff0c;除非是在没事才跟你认认真真看&#xff0c;所以&#xff0c;我们这类懒人就非常尴尬了&#xff0c;只能动不动查手册。 tp5也出很久了&#xff0c;本…

【Python】猜数小游戏(文件操作)

人生苦短&#xff0c;我用Python 关键词 1.多用户 2.字典记录所有成绩 3.每次游戏轮数&总游戏次数&平均每次游戏需要多少轮 字典Dictionary、列表List、元组Tuple差异化理解 from random import randintname input(请输入你的名字&#xff1a;)#输入玩家名字 #读取文件…

100ms的SQL把服务器搞崩溃了

前言一个项目上线了两个月&#xff0c;除了一些反馈的优化和小Bug之外&#xff0c;项目一切顺利&#xff1b;前期是属于推广阶段&#xff0c;可能使用人员没那么多&#xff0c;当然对于项目部署肯定提前想到并发量了&#xff0c;所以早就把集群安排上&#xff0c;而且还在测试环…

剑指offer之分行从上到下之字行打印二叉树

1 问题 分行从上到下之字行打印二叉树 比如二叉树 23 5 1 4 2 3 3 2 1 5 1 4 2 3 分行从上到下之字行打印二叉树结果如下 2 5 3 1 4 2 3 3 2 4 1 5 1 …

python中sendkeys.sendkeys_python的webbrowser模块和SendKeys模块

今天工作的时候突然遇到个问题&#xff0c;就尝试着按照领导所说要天马行空的想东西&#xff0c;于是那点scrapy的代码逐渐忘了的差不多了&#xff0c;想到用迅雷去下载一些东西&#xff0c;迅雷不知道怎么回事&#xff0c;但知道一点&#xff0c;他监控计算机浏览器&#xff0…

linux dns 动态更新时间,CentOS 7实现DNS+DHCP动态更新详解

然后再安装bind-chroot 执行/usr/libexec/setup-named-chroot.sh /var/named/chroot on 停用named&#xff0c;。昨天运维帮组织线下的沙龙&#xff0c;照着做又遇到各种问题&#xff0c;相信就能搞定了&#xff0c;最后不不知道到底什么原理实现的&#xff0c;man 5 dhcpd.con…

数组方法

json数据格式 <!DOCTYPE HTML><html><head><meta http-equiv"Content-Type" content"text/html; charsetutf-8"><title>无标题文档</title> <script>var json { name : leo, age : 32 };// alert( json.name )…

需求分析工程师岗位的职责描述(合集)

需求分析工程师岗位的职责描述1 职责&#xff1a; 1&#xff0c;负责需求调研&#xff0c;对需求进行分析&#xff0c;编写解决方案、需求规格说明书等 2&#xff0c;根据需求制作原型&#xff0c;并负责原型展示以及客户沟通等工作 3&#xff0c;负责向技术团队精确地传达业务…

基于.NET的系统开发需要注意的问题总结

从2009年进入大学校园以来,笔者渐渐对程序设计产生了浓厚的兴趣,对程序人生产生了深度的思考。记得刚开始学的第一门计算机语言就是风靡一时的Visual Basic,时至今日,时间已过了六年有余,已初步掌握了VB,C,C++,C#,Python,T-SQL等多种语言。回头想想,一路走来,真的很…

nginx 下配置使用Thinkphp5解决跨目录活动并且设置网站根目录

由于TP5框架的一些特性规则&#xff0c;在nginx下导致跨目录的一些访问不能执行 最开始我尝试配置文件夹目录&#xff0c;导致出现各种奇葩错误&#xff0c;然后搜了以下资料发现原来只要简单的修改几个配置文件即可。 声明系统环境&#xff1a; **系统&#xff1a;Centos6.版本…

剑指offer之先序非递归打印二叉树

1 问题 先序非递归打印二叉树 比如二叉树如下 * 2* 3 5 * 1 4 2 3 * 3 2 1 5 1 4 2 3 先序原则&#xff1a;中左右打印节点&#xff0c;如果左边有节点继续要打做节点&…

如何使用CPU来加速你的Linux命令

我们都知道 grep, bzip2, wc, awk, sed等等&#xff0c;都是单线程的&#xff0c;只能使用一个CPU内核。那么如何才能使用这些内核? 要想让Linux命令使用所有的CPU内核&#xff0c;我们需要用到GNU Parallel命令&#xff0c;它让我们所有的CPU内核在单机内做神奇的map-reduce操…

linux命令行设置编码,编码样式-Linux命令行开关和参数是否有标准?

-一种全部(不带参数)。 如果有GNU风格的--all选项&#xff0c;那么-a只能是同义词&#xff0c;这将是非常令人惊讶的。 示例&#xff1a;fuser(1)&#xff0c;fetchmail(1)。如tar(1)中所示追加。 通常将它与-d配对以进行删除。-b缓冲区或块大小(带参数)。 设置临界缓冲区大小&…

关于nginx为站点绑定域名以及绑定多个域名

环境&#xff1a; 系统&#xff1a;Centos6.版本 使用lnmp一键安装包安装环境&#xff08;配置文件地址在其官网有写&#xff09; 找到nginx的conf文件&#xff0c;我的目录为&#xff1a; /usr/local/nginx/conf 随后找到&#xff1a;server_name _; 如果没有配置就是…

【6】JAVA---地址App小软件(QueryPanel.class)(表现层)

查找模块&#xff1a; 年龄可进行段查找。 其他的都是模糊匹配。 空格为无用字符&#xff0c;会屏蔽的&#xff08;除年龄&#xff09;。 &#xff08;如果在年龄中输入空格&#xff0c;会出现异常&#xff0c;当时没想到这点&#xff0c;要防护这点很容易的&#xff0c;但…

Edge 超越 Safari 成为全球第二大桌面端浏览器!Firefox 爆降致 Chrome 份额再创新高!...

桌面端StatCounter 近日发布全球桌面端浏览器 2022 年 3 月统计报告&#xff1a;微软 Microsoft Edge 浏览器桌面端市场份额从 9.61% 上升至 9.65%&#xff0c; 苹果 Safari 浏览器桌面端市场份额从 9.77% 下降至 9.56%。 这也意味着微软 Microsoft Edge 浏览器正式超越苹果 Sa…