码蹄集OJ-魔法链路

MC0364・魔法链路

难度:黄金 时间限制:1 秒 占用内存:256 M 收藏 报错

小码妹学会了多重施法,也就是同时施放多个法术的能力,然而多重施法中每个最终施放的法术都需要一些前置的法力运转,这些中间的法力运转过程被称为魔法链路。

小码妹的魔法链路可以看作一个有向无环图(DAG),其中的每一个节点都可以看作一次法力运转,出度为 0 的节点则是一次最终施放的法术(法术也被视为一次法力运转)。每次法力运转都有一个魔力值wi​,每次法力运转都会获得其前置法力运转积累的魔力值以增加威力。

由于对多重施法的掌握并不熟练,小码妹不能很快知道自己进行法力运转的顺序,以及最终施放出的法术的威力,你能帮帮她吗?

小码妹喜欢有序的序列,所以她希望施放法力运转的最终顺序是字典序最小的。

格式

输入格式:第一行包含两个整数n,m(1≤n≤105,1≤m≤2×105),n表示法力运转的个数,m表示魔法链路的边数;
第二行包含n个整数,wi​(1≤wi​≤105)表示节点i的魔力值;
接下来m行,每行包含两个整数ui​,vi​,表示一条ui​到vi​的边。

输出格式:输出包含两行,第一行包含n个整数,为法力运转的最终顺序。
第二行包含每个最终施放法术的威力,按最终法术节点编号从小到大输出。

样例 1

输入

5 5
1 2 3 4 5
1 2
1 3
2 4
3 4
3 5

输出

1 2 3 4 5
11 9
备注

样例说明
最终施放的法术为 4,5。
施放法术 4 需要法力运转 2,3,法力运转 2,3 均会获得法力运转 1 的 1 点魔力值,所以施放法术 4 的威力为(1+2)+(1+3)+4=11。
施放法术 5 需要法力运转 3,法力运转 3 会获得法力运转 1 的 1 点魔力值,所以施放法术 3 的威力为1+3+5=9。

本题相关知识点: 图论:拓扑排序

代码:
 

#include<bits/stdc++.h> 
using namespace std;
const int N = 1e5+10;
vector <int> G[N];
int val[N],ru[N],chu[N];
int n,m;
int main( )
{priority_queue <int,vector<int>,greater<int>> qp;cin >> n >> m;for(int i = 1 ; i <= n ; i++){cin >> val[i];	}for(int i = 1 ; i <= m ; i++){int u,v;cin >> u >> v;G[u].push_back(v);ru[v]++;chu[u]++;}for(int i = 1 ; i <= n ; i++){if(ru[i] == 0){qp.push(i);}}while(!qp.empty()){int cur = qp.top();qp.pop();cout << cur << " ";for(auto to : G[cur]){val[to] += val[cur];ru[to]--;if(ru[to] == 0){qp.push(to);}}} cout << endl;for(int i = 1 ; i <= n ; i++){if(chu[i] == 0)cout << val[i] << " ";}return 0;
}

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

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

相关文章

《解密React key:虚拟DOM Diff中的节点身份锚点》

在React的性能优化体系中&#xff0c;key属性始终是一个看似简单却暗藏玄机的存在。它并非可有可无的标记&#xff0c;而是虚拟DOM Diff算法识别节点身份的核心锚点&#xff0c;直接决定着React如何判断节点是否需要重渲染、如何复用已有元素。理解key的本质&#xff0c;不仅能…

react 和 react native 的开发过程区别

React 和 React Native 虽然都使用 React 思想和语法&#xff08;函数组件、Hooks、JSX 等&#xff09;&#xff0c;但在 开发流程、渲染机制、UI 组件、样式处理、运行平台 等方面有明显差异。以下是对比总结&#xff1a;✅ 一、开发目的和平台不同对比项ReactReact Native应用…

什么是股指期货的不对冲策略?

不对冲策略的核心思想是把股指期货当作ETF基金来用。ETF基金是一种跟踪指数的基金&#xff0c;比如沪深300ETF&#xff0c;它会按照沪深300指数的成分股比例来配置资产。而股指期货则是直接跟踪沪深300指数的期货合约。假设现在沪深300指数是4000点&#xff0c;你有120万资金。…

C++ vector底层实现与迭代器失效问题

目录 前言 一、vector 的框架 二、基础实现 1、无参的构造&#xff1a; 2、析构函数 3、size 4、capacity 5、reserve扩容 6、push_back 7、迭代器 8、 operator[ ] 9、pop_back 10、insert 以及 迭代器失效问题 11、erase 以及 迭代器失效问题 12、resize 13、 拷贝…

HTML 表单详解:构建用户交互的完整指南

在上一篇文章中&#xff0c;我们学习了HTML的基础标签和页面结构。今天我们将深入探讨HTML中最重要的交互元素——表单。表单是网页与用户交互的核心组件&#xff0c;从简单的登录页面到复杂的数据收集系统&#xff0c;都离不开表单的支持。表单基础概念表单&#xff08;Form&a…

云原生周刊:2025年的服务网格

开源项目推荐 kaito kaito 是由微软开源并托管于 GitHub 的项目&#xff0c;旨在自动化在 K8s&#xff08;主目前支持 Azure AKS&#xff09;中部署与管理大型语言模型&#xff08;如 Falcon、Phi‑3、Llama&#xff09;推理及微调工作负载。它通过定义 CRD&#xff08;Works…

国产开源大模型崛起:使用Kimi K2/Qwen2/GLM-4.5搭建编程助手

近期&#xff0c;国产大模型领域的发展令人瞩目&#xff0c;多款高性能开源模型的涌现&#xff0c;为我们开发者带来了前所未有的机遇。这些模型不仅在各大基准测试中名列前茅&#xff0c;其强大的代码能力也为我们打造个性化的编程助手提供了坚实的基础。HuggingFace的开源大模…

浅析责任链模式在视频审核场景中的应用

本文字数&#xff1a;3161字预计阅读时间&#xff1a;20分钟01设计模式设计模式的概念出自《Design Patterns - Elements of Reusable Object-Oriented Software》中文名是《设计模式 - 可复用的面向对象软件元素》&#xff0c;该书是在1994 年由 Erich Gamma、Richard Helm、R…

洛谷 P3372 【模板】线段树 1-普及+/提高

题目描述 如题&#xff0c;已知一个数列 {ai}\{a_i\}{ai​}&#xff0c;你需要进行下面两种操作&#xff1a; 将某区间每一个数加上 kkk。求出某区间每一个数的和。 输入格式 第一行包含两个整数 n,mn, mn,m&#xff0c;分别表示该数列数字的个数和操作的总个数。 第二行包含 n…

flink写paimon表的过程解析

背景 apache paimon是构建湖仓一体的重要组成部分&#xff0c;由于paimon的写入速度很快&#xff0c;通过flink进行数据写入是很自然的选择&#xff0c;本文就介绍下使用flink写入paimon的两阶段协议的大概逻辑 技术实现 flink通过两阶段协议写入paimon表&#xff0c;分成三个步…

迅为RK3568开发板OpeHarmony学习开发手册-点亮 HDMI 屏幕

OpenHarmony 源码中默认支持 HDMI 屏幕&#xff0c;但是默认的分辨率是采用 mipi 的分辨率&#xff0c;我们修改代码&#xff0c;关闭 MIPI 就可以正常显示了。在之前视频修改的基础上&#xff0c;修改/home/topeet/OH4.1/OpenHarmony-v4.1-Release/OpenHarmony/out/kernel/src…

北京理工大学医工交叉教学实践分享(1)|如何以实践破解数据挖掘教学痛点

如何有效提升医工交叉领域数据挖掘课程的教学效果&#xff1f;近日&#xff0c;北京理工大学医学技术学院辛怡副教授在和鲸组织的分享会上&#xff0c;系统介绍了其团队在《数据挖掘在生物医学中的应用》课程中的创新实践&#xff0c;为解决普遍教学痛点提供了可借鉴的“平台化…

Vue 3 入门教程 8 - 路由管理 Vue Router

一、Vue Router 简介Vue Router 是 Vue.js 官方的路由管理器&#xff0c;它与 Vue.js 核心深度集成&#xff0c;用于构建单页面应用&#xff08;SPA&#xff09;。单页面应用是指整个应用只有一个 HTML 页面&#xff0c;通过动态切换页面内容来模拟多页面跳转的效果&#xff0c…

django的数据库原生操作sql

from django.db import connection from django.db import transaction from django.db.utils import (IntegrityError,OperationalError,ProgrammingError,DataError ) from django.utils import timezoneclass Db(object):"""数据库操作工具类&#xff0c;封装…

FreeRTOS---基础知识2

1. FreeRTOS 调度机制概述FreeRTOS 是一个实时操作系统&#xff08;RTOS&#xff09;&#xff0c;其核心功能是通过 调度器&#xff08;Scheduler&#xff09; 管理多个任务的执行。调度机制决定了 何时切换任务 以及 如何选择下一个运行的任务&#xff0c;以满足实时性、优先级…

Docker安装(精简述版)

1. 安装&#xff1a;Docker 环境&#xff08;Docker desktop&#xff09; #Windows架构版本查看&#xff0c;Win R‌ 输入 ‌cmd‌ 打开命令提示符&#xff1b;输入命令‌&#xff1a; bash echo %PROCESSOR_ARCHITECTURE%#安装Docker desktop&#xff08;安装时勾选 WSL2&am…

Postman-win64-7.3.5-Setup.exe安装教程(附详细步骤+桌面快捷方式设置)​

Postman 是一款超常用的接口调试工具&#xff0c;程序员和测试人员用它来发送网络请求、测试API接口、调试数据交互​ 1. 双击安装包​ 安装包下载地址&#xff1a;https://pan.quark.cn/s/4b2960d60ae9&#xff0c;找到你下的 Postman-win64-7.3.5-Setup.exe 文件&#xff08…

149. Java Lambda 表达式 - Lambda 表达式的序列化

文章目录149. Java Lambda 表达式 - Lambda 表达式的序列化为什么要序列化 Lambda 表达式&#xff1f;Lambda 表达式的序列化规则示例代码&#xff1a;序列化 Lambda 表达式代码解析&#xff1a;Lambda 序列化的限制总结&#xff1a;149. Java Lambda 表达式 - Lambda 表达式的…

颐顿机电携手观远BI数据:以数据驱动决策,领跑先进制造智能化升级

颐顿机电签约观远数据&#xff0c;聚焦财务分析、销售管理等场景&#xff0c;以 BI 数据解决方案推进数据驱动决策&#xff0c;助力先进制造企业提效与竞争力升级。一、合作官宣&#xff1a;颐顿机电 观远数据&#xff0c;开启数据应用新征程浙江颐顿机电有限公司&#xff08;…

【PHP】几种免费的通过IP获取IP所在地理位置的接口(部分免费部分收费)

目录 一、获取客户端IP地址 二、获取IP所在地理位置接口 1、IP域名归属地查询 2、腾讯地图 - IP定位 3、聚合数据 - IP地址&#xff08;推荐&#xff09; 4、高德地图 - IP定位&#xff08;推荐&#xff09; 5、360分享计划 - IP查询 6、天聚ip地址查询 7、百度IP地址…