news 2025/12/16 20:38:39

打卡信奥刷题(2531)用C++实现信奥 P2024 [NOI2001] 食物链

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2531)用C++实现信奥 P2024 [NOI2001] 食物链

P2024 [NOI2001] 食物链

题目描述

动物王国中有三类动物A,B,CA,B,CA,B,C,这三类动物的食物链构成了有趣的环形。AAABBBBBBCCCCCCAAA

现有NNN个动物,以1∼N1 \sim N1N编号。每个动物都是A,B,CA,B,CA,B,C中的一种,但是我们并不知道它到底是哪一种。

有人用两种说法对这NNN个动物所构成的食物链关系进行描述:

  • 第一种说法是1 X Y,表示XXXYYY是同类。
  • 第二种说法是2 X Y,表示XXXYYY

此人对NNN个动物,用上述两种说法,一句接一句地说出KKK句话,这KKK句话有的是真的,有的是假的。当一句话满足下列三条之一时,这句话就是假话,否则就是真话。

  • 当前的话与前面的某些真的话冲突,就是假话;
  • 当前的话中XXXYYYNNN大,就是假话;
  • 当前的话表示XXXXXX,就是假话。

你的任务是根据给定的NNNKKK句话,输出假话的总数。

输入格式

第一行两个整数,N,KN,KN,K,表示有NNN个动物,KKK句话。

第二行开始每行一句话。格式见题目描述与样例。

输出格式

一行,一个整数,表示假话的总数。

输入输出样例 #1

输入 #1

100 7 1 101 1 2 1 2 2 2 3 2 3 3 1 1 3 2 3 1 1 5 5

输出 #1

3

说明/提示

对于全部数据,1≤N≤5×1041\le N\le 5 \times 10^41N5×1041≤K≤1051\le K \le 10^51K105

C++实现

#include<cstdio>inlineintread(){charc=getchar();intn=0;while(c<'0'||c>'9'){c=getchar();}while(c>='0'&&c<='9'){n=(n<<1)+(n<<3)+(c&15);c=getchar();}returnn;}constintmaxN=100005;intn,m,ans,fa[maxN*3];intfind(intu){returnfa[u]==u?u:fa[u]=find(fa[u]);}intmain(){n=read(),m=read();for(inti=1;i<=n*3;i++){fa[i]=i;}for(;m;m--){intopt=read(),u=read(),v=read();if(u>n||v>n){ans++;continue;}if(opt==1){if(find(u+n)==find(v)||find(u)==find(v+n)){ans++;}else{fa[find(u)]=find(v);fa[find(u+n)]=find(v+n);fa[find(u+n+n)]=find(v+n+n);}}else{if(find(u)==find(v)||find(u)==find(v+n)){ans++;}else{fa[find(u+n)]=find(v);fa[find(u+n+n)]=find(v+n);fa[find(u)]=find(v+n+n);}}}printf("%d\n",ans);return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/13 16:36:18

如何快速掌握Step1X-3D:新手入门完整指南

如何快速掌握Step1X-3D&#xff1a;新手入门完整指南 【免费下载链接】Step1X-3D 项目地址: https://ai.gitcode.com/StepFun/Step1X-3D 你是否曾经梦想过将脑海中的创意瞬间转化为真实的3D模型&#xff1f;现在&#xff0c;这个梦想已经触手可及&#xff01;Step1X-3D…

作者头像 李华
网站建设 2025/12/13 16:35:52

Facebook iOS SDK实战指南:从零构建社交应用

Facebook iOS SDK实战指南&#xff1a;从零构建社交应用 【免费下载链接】facebook-ios-sdk facebook/facebook-ios-sdk: Facebook iOS SDK 是一套官方提供的 iOS 平台开发工具包&#xff0c;允许开发者将 Facebook 登录、分享、广告等功能集成到自己的 iOS 应用程序中。 项目…

作者头像 李华
网站建设 2025/12/13 16:35:43

C++ Vector在实际项目中的5个典型应用场景

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请生成一个完整的C项目&#xff0c;展示Vector在游戏开发中的实际应用&#xff1a;1. 实现一个简单的敌人管理系统&#xff0c;使用Vector存储敌人对象&#xff1b;2. 添加敌人生成…

作者头像 李华
网站建设 2025/12/13 16:35:14

命令行效率革命:用Shell工具实现API文档自动化生成

命令行效率革命&#xff1a;用Shell工具实现API文档自动化生成 【免费下载链接】awesome-shell A curated list of awesome command-line frameworks, toolkits, guides and gizmos. Inspired by awesome-php. 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-shell …

作者头像 李华
网站建设 2025/12/13 16:35:03

3步精通微信小程序逆向分析:unwxapkg资源提取实战指南

在微信小程序逆向分析和资源提取工具领域&#xff0c;unwxapkg凭借其高效的.wxapkg文件解析能力&#xff0c;为开发者提供了深入理解小程序内部架构的独特视角。通过这款专业的小程序逆向分析工具&#xff0c;我们可以轻松提取出包括页面逻辑、样式配置、图片素材在内的完整资源…

作者头像 李华
网站建设 2025/12/13 16:34:54

45、Red Hat Linux 网络安全与服务管理全攻略

Red Hat Linux 网络安全与服务管理全攻略 1. 渗透测试与端口扫描 渗透测试的一个重要方面是查看 Red Hat Linux 系统上哪些端口是开放的。端口号是用于标识与系统的特定 TCP/IP 网络连接的数字。只有当某个端口上运行着服务器(即服务器在“监听”该端口)时,连接该端口的尝…

作者头像 李华