当前位置: 首页 > news >正文

打卡信奥刷题(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考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

http://www.cnnetsun.cn/news/39547.html

相关文章:

  • 如何快速掌握Step1X-3D:新手入门完整指南
  • Facebook iOS SDK实战指南:从零构建社交应用
  • C++ Vector在实际项目中的5个典型应用场景
  • 命令行效率革命:用Shell工具实现API文档自动化生成
  • 3步精通微信小程序逆向分析:unwxapkg资源提取实战指南
  • 45、Red Hat Linux 网络安全与服务管理全攻略
  • 5分钟用AI搭建EFI网络启动原型
  • Konva.js拖拽功能实战技巧:构建高效Canvas交互界面
  • DeepSeek-V3:6710亿参数开源模型如何重塑企业AI格局
  • CodeBlocks开发效率翻倍:AI对比传统编程方式
  • Folo信息浏览器:彻底改变你获取信息的方式
  • 10秒生成商用级3D模型:混元3D如何颠覆传统创作?
  • 5分钟用AI生成支持特殊类型的深拷贝工具函数
  • 如何用AI自动生成BeautifulSoup爬虫代码?
  • 3分钟快速验证kb2919355补丁修复方案
  • 企业级EFI网络部署实战指南
  • Prompt工程 vs 传统开发:效率提升300%的秘诀
  • 7步精通企业架构可视化:ArchiMate工具终极实战指南
  • AI如何帮你自动生成CodeBlocks项目?快马平台实战
  • EverythingToolbar终极集成指南:3步实现Windows秒级文件搜索
  • 均方误差(MSE)图解:小白也能懂的评估指标
  • 企业级VS Code汉化解决方案:200人团队实战案例
  • Qwen3-14B-AWQ:如何用单张消费级显卡运行140亿参数大模型?
  • 18、PHP中GD库实现图像操作全解析
  • 20、PHP扩展与AJAX技术深度解析
  • GitBash在企业级项目中的实战技巧
  • Phoenix LiveView 错误处理完全指南:构建坚不可摧的实时应用
  • DBeaver连接提速:绕过公钥检索的3种高效方法
  • 零基础教程:Windows 11安装配置Android子系统的完整指南
  • 仓颉编程语言终极指南:从零开始的快速安装与开发实战