首页 > 其他分享 >逐月信息学 2024 提高组 #3

逐月信息学 2024 提高组 #3

时间:2024-07-06 15:09:25浏览次数:21  
标签:信息学 删除 int mid 2024 MAXN 逐月 代价 翻转

\(\color{black}\texttt{A. 反转Dag图}\)

题目描述

给定一个有向图,每次操作可以花费 \(w_i\) 的代价来反转边 \(i\),最终总代价为每次操作代价的最大值。求最少需要多少代价才能使这张图变为一个 DAG。

思路

首先看这个问题的简化版:把反转操作变为删除操作。

可以用二分解决:二分出最终答案 \(x\),把所有代价 \(\le x\) 的边删掉,再拓扑排序判断即可。

这时可以发现,两个问题竟然是等价的:假设有 \(u\rightarrow v\) 这条边,如果 \(u\) 的拓扑序小于 \(v\),则这条边不用删除或翻转;否则这条边必须删除或翻转。即要删除一定会翻转,反之亦然。

代码

#include<bits/stdc++.h>
using namespace std;
using pii = pair<int, int>;

const int MAXN = 100001, MAXM = 100005;

struct Edge {
  int v, w;
};

int n, m, in[MAXN];
vector<Edge> e[MAXN];

void FileIO(const string &s) {
  freopen((s + ".in").c_str(), "r", stdin);
  freopen((s + ".out").c_str(), "w", stdout);
}

bool check(int x) {
  queue<int> que;
  fill(in + 1, in + n + 1, 0);
  for(int i = 1; i <= n; ++i) {
    for(auto [v, w] : e[i]) {
      in[v] += (w > x);
    }
  }
  for(int i = 1; i <= n; ++i) {
    if(!in[i]) {
      que.push(i);
    }
  }
  for(; !que.empty(); ) {
    int u = que.front();
    que.pop();
    for(auto [v, w] : e[u]) {
      if(w > x && !(--in[v])) {
        que.push(v);
      }
    }
  }
  for(int i = 1; i <= n; ++i) {
    if(in[i]) {
      return 0;
    }
  }
  return 1;
}

int Binary_Search() {
  int l = 0, r = 1000000001;
  for(; l < r; ) {
    int mid = (l + r) >> 1;
    (check(mid) ? r = mid : l = mid + 1);
  }
  return l;
}

int main() {
  ios::sync_with_stdio(false), cin.tie(0), cout.tie(0);
  FileIO("antidag");
  cin >> n >> m;
  for(int i = 1, u, v, w; i <= m; ++i) {
    cin >> u >> v >> w;
    e[u].push_back({v, w});
  }
  cout << Binary_Search();
  return 0;
}

标签:信息学,删除,int,mid,2024,MAXN,逐月,代价,翻转
From: https://www.cnblogs.com/yaosicheng124/p/18287269

相关文章

  • 跟《经济学人》学英文:2024年07月06日这期 Central banks are winning the battle agai
    Centralbanksarewinningthebattleagainstinflation.ButthewarisjustgettingstartedPoliticsandprotectionismwillmakelifedifficult原文:Thetrajectoryofinflationhasnotgivencentralbankersmuchcauseforcelebrationinrecentyears.B......
  • CDR2024永久免激活版下载附带CorelDRAW软件序列号激活码
    在设计领域,CorelDRAW一直以其强大的功能和易用性受到设计师们的喜爱。而随着移动设备的普及,许多人都期待着能在安卓设备上也能使用这一软件。但是,众所周知,由于版权等问题,官方并没有直接推出安卓版。这就让许多用户开始寻找其他途径,比如破解版。1、在本站下载并解压,禁用网络连......
  • [图解]企业应用架构模式2024新译本讲解19-数据映射器1
    100:00:01,720-->00:00:03,950下一个我们要讲的就是200:00:04,660-->00:00:07,420数据映射器这个模式300:00:09,760-->00:00:13,420这个也是在数据源模式里面400:00:13,430-->00:00:14,820用得最广泛的500:00:16,250-->00:00:19,170大多数都是用600:......
  • 2024年用云电脑玩游戏靠谱吗,软件推荐
    不知道大家有没有尝试过用云电脑来玩游戏?是否清楚云电脑是什么?为什么要用云电脑来游戏?这个操作是否靠谱及划算?本期内容小编就为大家科普一下关于云电脑及借助云电脑畅玩游戏的相关信息,屏幕前的你可要认真阅读学经验喔,如果觉得内容有用不妨收藏+转发做支持哟~什么是云电脑?为......
  • 【中国算力大会分会,SPIE独立出版!AHPCAI前三届已完成EI检索!】2024算法、高性能计算与人
    2024算法、高性能计算与人工智能国际学术会议(AHPCAI2024)定于2024年8月14-16日在中国郑州举行。会议主要围绕算法、高性能计算与人工智能等研究领域展开讨论。会议旨在为从事算法、高性能计算与人工智能研究的专家学者、工程技术人员、技术研发人员提供一个共享科研成果......
  • 【JPCS独立出版★EI检索稳定★中国科学院院士、IEEE Fellow大咖与会报告】2024年航空
    2024年航空航天与力学国际学术会议(ICAM2024)将于2024年7月12-14日在中国沈阳举办。会议由东北大学机械工程与自动化学院主办,吉林大学机械与航空航天工程学院承办,大连理工大学、沈阳航空航天大学、沈阳建筑大学、沈阳工业大学、沈阳化工大学、东北电力大学协办。大会旨在......
  • 2024年6月后2周重要的大语言模型论文总结:LLM进展、微调、推理和对齐
    本文总结了2024年6月后两周发表的一些最重要的大语言模型论文。这些论文涵盖了塑造下一代语言模型的各种主题,从模型优化和缩放到推理、基准测试和增强性能。LLM进展与基准1、BigCodeBench:BenchmarkingCodeGenerationwithDiverseFunctionCallsandComplexInstructions......
  • Python 潮流周刊#59:Polars 1.0 发布了,PyCon US 2024 演讲视频也发布了(摘要)
    本周刊由Python猫出品,精心筛选国内外的250+信息源,为你挑选最值得分享的文章、教程、开源项目、软件工具、播客和视频、热门话题等内容。愿景:帮助所有读者精进Python技术,并增长职业和副业的收入。本期周刊分享了12篇文章,12个开源项目,2则视频,全文2200字,赠书5本。重......
  • 20240706
    import{createApi,fetchBaseQuery}from'@reduxjs/toolkit/query/react';interfaceMuniData{serviceName:string;updatedAt:string;region:string;status:string;message:string;expandedRow:ExpandedRowData[];}interfaceExp......
  • HTML 【实用教程】(2024最新版)
    核心思想——语义化【面试题】如何理解HTML语义化?仅通过标签便能判断内容的类型,特别是区分标题、段落、图片和表格增加代码可读性,让人更容易读懂对SEO更加友好,让搜索引擎更容易读懂html文件的基本结构html文件的文件后缀为.html,如index.htmlvscode中......