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

排水系统C++

题目:


样例解释:

1 号结点是接收口,4,5 号结点没有排出管道,因此是最终排水口。
1 吨污水流入 1 号结点后,均等地流向 2,3,5 号结点,三个结点各流入 1/3 吨污水。
2 号结点流入的 1/3​ 吨污水将均等地流向 4,5 号结点,两结点各流入 1/6 吨污水。
3 号结点流入的 1/3 吨污水将均等地流向 4,5 号结点,两结点各流入 1/6 吨污水。
最终,4 号结点排出 1/6​+1/6=1/3 吨污水,5 号结点排出 1/3​+1/6​+1/6​=2/3​ 吨污水。


思路+部分代码:

 

拓扑排序主要思路在一个有向无环图中,先统计出每个点的入度个数,然后将入度为0的点入队,接着把队中每个点向它的出边做一个运算(本题中是将水分流到与其相连节点),然后断边(相连的点入度-1),最后就会得出排水节点的水量。

有不明白的同学可以看 神经网络 车站分级 旅行计划 都是很好的拓扑排序模板题。

拓扑排序函数:

void tp(){for(int i=1;i<=n;i++)//所有入度为0的点入队(1-m)if(!in[i]){book[i]=1;q.push(i);xx[i]=1,yy[i]=1;}while(!q.empty()){int p=q.front();q.pop();if(out[p])continue;for(int i=0;i<a[p].size();i++){add(a[p][i],xx[p],yy[p]*(1ll*a[p].size()));if(book[a[p][i]])continue;in[a[p][i]]--;if(in[a[p][i]]==0){book[a[p][i]]=1;q.push(a[p][i]);}}}return;
}

注意几点:

  1. 如果是 vector 存边,一定不要访问排水节点的 size() 这样可能会炸,要事先存一下。

     2.本题是前 m 个点是入水口,一定要注意审好题(虽然只有前 m 个点入度为0)。

分数处理

我主要运用的是通分思想:

紧接着用 gcd 化简

ll gcd(ll x,ll y){if(y==0)return x;return gcd(y,x%y);
}

下面是通分代码:

void add(int u,ll x,ll y){if(y==0)return;if(yy[u]==0){xx[u]=x;yy[u]=y;return;}ll p1=xx[u]*y+yy[u]*x;ll p2=yy[u]*y;ll p3=gcd(p1,p2);xx[u]=p1/p3;yy[u]=p2/p3;return;
}

注意事项:

1.一定要判出要添加的分母是否为0,如果为0 直接赋值即可。

2.最后输出保险在约分一下。


代码:

#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<queue>
#include<stack>
#include<vector>
#include<map>
#define ll long long
using namespace std;
inline ll read(){ll x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f;
}
int n,m,in[100001],out[100001],book[100001];
ll xx[100001],yy[100001];
ll gcd(ll x,ll y){if(y==0)return x;return gcd(y,x%y);
}
void add(int u,ll x,ll y){if(y==0)return;if(yy[u]==0){xx[u]=x;yy[u]=y;return;}ll p1=xx[u]*y+yy[u]*x;ll p2=yy[u]*y;ll p3=gcd(p1,p2);xx[u]=p1/p3;yy[u]=p2/p3;return;
}
vector<int> a[500001];
queue<int> q;
void tp(){for(int i=1;i<=n;i++)if(!in[i]){book[i]=1;q.push(i);xx[i]=1,yy[i]=1;}while(!q.empty()){int p=q.front();q.pop();if(out[p])continue;for(int i=0;i<a[p].size();i++){add(a[p][i],xx[p],yy[p]*(1ll*a[p].size()));if(book[a[p][i]])continue;in[a[p][i]]--;if(in[a[p][i]]==0){book[a[p][i]]=1;q.push(a[p][i]);}}}return;
}
int main()
{//freopen("water.in","r",stdin);//freopen("water.out","w",stdout);n=read(),m=read();for(int i=1;i<=n;i++){int d=read();if(d==0){out[i]=1;continue;}while(d--){int v;v=read();a[i].push_back(v);in[v]++;}}tp();for(int i=1;i<=n;i++){if(out[i]){add(i,0,1);printf("%lld %lld\n",xx[i],yy[i]);}}return 0;
}

总结: 

如果说去掉高精度的话,还是一道非常好的 拓扑 排序题目。


代码注意事项:

代码无高精,请自行添加 

相关文章:

  • 对象存储极简理解(对象、存储桶)
  • kubeadm部署k8s集群,版本1.23.6;并设置calico网络BGP模式通信,版本v3.25--未完待续
  • Java基础 3. 面向对象
  • DevExpress WinForms中文教程:Data Grid - 如何添加或删除行?
  • 浏览器插件的标准项目结构通常包括以下几个目录和文件
  • c语言手撕内存池组件
  • 利用Puppeteer-Har记录与分析网页抓取中的性能数据
  • 网络安全 DVWA通关指南 DVWA Weak Session IDs(弱会话)
  • C++中数据类型的大小
  • 【spring中event】事件简单使用
  • 【MySQL】数据目录迁移
  • 前端 vue3 对接科大讯飞的语音在线合成API
  • 详细指南:如何有效解决Windows系统中msvcp140.dll丢失的解决方法
  • 【cache】浅析四种常用的缓存淘汰算法 FIFO/LRU/LFU/W-TinyLFU
  • spark计算引擎-架构和应用
  • (十五)java多线程之并发集合ArrayBlockingQueue
  • [ 一起学React系列 -- 8 ] React中的文件上传
  • [分享]iOS开发 - 实现UITableView Plain SectionView和table不停留一起滑动
  • Java反射-动态类加载和重新加载
  • js ES6 求数组的交集,并集,还有差集
  • KMP算法及优化
  • Node项目之评分系统(二)- 数据库设计
  • SQL 难点解决:记录的引用
  • Tornado学习笔记(1)
  • VuePress 静态网站生成
  • webpack项目中使用grunt监听文件变动自动打包编译
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 跨域
  • 扫描识别控件Dynamic Web TWAIN v12.2发布,改进SSL证书
  • 使用Swoole加速Laravel(正式环境中)
  • 一、python与pycharm的安装
  • 一加3T解锁OEM、刷入TWRP、第三方ROM以及ROOT
  • d²y/dx²; 偏导数问题 请问f1 f2是什么意思
  • ​Kaggle X光肺炎检测比赛第二名方案解析 | CVPR 2020 Workshop
  • # Java NIO(一)FileChannel
  • # Spring Cloud Alibaba Nacos_配置中心与服务发现(四)
  • #我与Java虚拟机的故事#连载17:我的Java技术水平有了一个本质的提升
  • ()、[]、{}、(())、[[]]等各种括号的使用
  • (1)svelte 教程:hello world
  • (4) openssl rsa/pkey(查看私钥、从私钥中提取公钥、查看公钥)
  • (附源码)springboot人体健康检测微信小程序 毕业设计 012142
  • (附源码)计算机毕业设计SSM疫情下的学生出入管理系统
  • (附源码)计算机毕业设计SSM智能化管理的仓库管理
  • (实战)静默dbca安装创建数据库 --参数说明+举例
  • (一)RocketMQ初步认识
  • (一)u-boot-nand.bin的下载
  • (中等) HDU 4370 0 or 1,建模+Dijkstra。
  • (转)linux 命令大全
  • (转)Linux整合apache和tomcat构建Web服务器
  • (转)Scala的“=”符号简介
  • .NET Core 项目指定SDK版本
  • .Net IE10 _doPostBack 未定义
  • .NET 发展历程
  • .NET 药厂业务系统 CPU爆高分析
  • .NetCore部署微服务(二)