码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 洛谷P4185 离线+并查集


    好题,发现没有强制在线,可以离线操作

    排序之后带集合点数的并查集就好了

    1. #include
    2. using namespace std;
    3. const int N = 1e5+10;
    4. int n,m;
    5. int p[N],sz[N];
    6. int find(int x){
    7. if(x!=p[x])p[x] = find(p[x]);
    8. return p[x];
    9. }
    10. struct Node{
    11. int k,v,id;
    12. bool operator<(const Node&W)const{
    13. return k>W.k;
    14. }
    15. }query[N];
    16. struct Edge{
    17. int p,q,r;
    18. bool operator<(const Edge&Ws)const{
    19. return r>Ws.r;
    20. }
    21. }edge[N];
    22. vector<int>ans(100020,0);
    23. int main()
    24. {
    25. cin>>n>>m;
    26. for(int i=1;i<=n;i++)p[i] = i,sz[i] = 1;
    27. for(int i=1;i<=n-1;i++){
    28. int p,q,r;cin>>p>>q>>r;
    29. edge[i] = {p,q,r};
    30. }
    31. for(int i=1;i<=m;i++){
    32. int k,v;cin>>k>>v;
    33. query[i] = {k,v,i};
    34. }
    35. sort(edge+1,edge+1+n-1);
    36. sort(query+1,query+1+m);
    37. for(int i=1,j=0;i<=m;i++){
    38. int ks = query[i].k;
    39. while(j+1<=n&&edge[j+1].r>=ks){
    40. ++j;
    41. int a = find(edge[j].p),b = find(edge[j].q);
    42. if(a!=b){
    43. sz[b]+=sz[a];
    44. p[a] = b;
    45. }
    46. }
    47. ans[query[i].id] = sz[find(query[i].v)]-1;
    48. }
    49. for(int i=1;i<=m;i++)cout<"\n";
    50. }

  • 相关阅读:
    【RTOS训练营】环形缓冲区、AT指令、预习安排和晚课提问
    数据库系统概念系列 - 数据库系统的历史
    java毕业设计校园便利店信息系统开发源码+lw文档+mybatis+系统+mysql数据库+调试
    超越GPT-3,DeepMind推出新宠Gato,却被质疑“换汤不换药”?
    05-Flask-Flask查询路由方式
    使用CLion和gdb server debug haproxy
    【Spring Cloud】Ribbon负载均衡
    Redis的发布与订阅
    AcWing 246. 区间最大公约数----线段树 + 差分模板题
    C++继承
  • 原文地址:https://blog.csdn.net/m0_60921016/article/details/134319871
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号