P2765 魔术球问题

贪心模拟就可以过.........好像和dinic没啥关系
 
找找规律发现可以贪心放。n又灰常小。
设答案=m
你可以$O(mn)$直接模拟过去
闲的慌得话可以像我用个$set$维护
复杂度可以降为$O(mlogn)$
网络流.....不会写(逃
 
口胡一下dinic
一个点$u$拆成2个表示
1.放在柱子最下面,与S连接(u)
2.满足和下面的数的和为完全平方数,与T连接(u')
满足关系的两个点u、v,建立v-u'
当一个点被加入后,它就相当于放在最下面的点了。
去看luogu的题解吧(逃
 
  1. #include<iostream>
  2. #include<cstdio>
  3. #include<set>
  4. using namespace std;
  5. struct data{
  6. int val,id;
  7. bool operator < (const data &A) const{return val<A.val;}
  8. };
  9. set<data> s;
  10. set<data>::iterator it;
  11. int n,w=,tp[][];
  12. int main(){
  13. scanf("%d",&n);
  14. s.insert((data){,});
  15. for(int i=;;++i){
  16. while(i+(*s.begin()).val>w*w) ++w;
  17. it=s.upper_bound((data){w*w-i,}); --it;
  18. if((*it).val+i!=w*w){
  19. if(s.size()==n){printf("%d\n",i-);break;}
  20. else{
  21. int tmp=s.size()+;
  22. s.insert((data){i,tmp});
  23. }
  24. }else{
  25. tp[(*it).id][++tp[(*it).id][]]=(*it).val;
  26. s.insert((data){i,(*it).id}); s.erase(*it);
  27. }
  28. }
  29. for(it=s.begin();it!=s.end();++it)
  30. tp[(*it).id][++tp[(*it).id][]]=(*it).val;
  31. for(int i=;i<=n;++i){
  32. for(int j=;j<=tp[i][];++j) printf("%d ",tp[i][j]);
  33. printf("\n");
  34. }return ;
  35. }

P2765 魔术球问题的更多相关文章

  1. 洛谷 P2765 魔术球问题 解题报告

    P2765 魔术球问题 题目描述 问题描述: 假设有\(n\)根柱子,现要按下述规则在这\(n\)根柱子中依次放入编号为\(1,2,3,\dots\)的球. \((1)\) 每次只能在某根柱子的最上面 ...

  2. 洛谷 P2765 魔术球问题 (dinic求最大流,最小边覆盖)

    P2765 魔术球问题 题目描述 «问题描述: 假设有n根柱子,现要按下述规则在这n根柱子中依次放入编号为1,2,3,...的球. (1)每次只能在某根柱子的最上面放球. (2)在同一根柱子中,任何2 ...

  3. P2765 魔术球问题 网络流二十四题重温

    P2765 魔术球问题 知识点::最小点覆盖 这个题目要拆点,这个不是因为每一个球只能用一次,而是因为我们要求最小点覆盖,所以要拆点来写. 思路: 首先拆点,然后就是开始建边,因为建边的条件是要求他们 ...

  4. 洛谷P2765魔术球问题 最小路径覆盖

    https://www.luogu.org/problemnew/show/P2765 看到这一题第一眼想到:这不是二分最大流吗,后来发现还有一种更快的方法. 首先如果知道要放多少个球求最少的柱子,很 ...

  5. 洛谷 [P2765] 魔术球问题

    贪心做法 每次尽可能选择已经放过球的柱子 #include <iostream> #include <cstdio> #include <cstring> #inc ...

  6. 洛谷P2765 魔术球问题(最大流)

    传送门 %%%KSkun大佬 话说明明是网络流……这题竟然还有打表找规律和纯贪心AC的……都是神犇啊…… 来说一下如何建图.首先把每一个点拆成$X_i$和$Y_i$,然后$S$向$X_i$连一条容量为 ...

  7. P2765 魔术球问题(网络流24题)

    题目描述 «问题描述: 假设有n根柱子,现要按下述规则在这n根柱子中依次放入编号为1,2,3,...的球. (1)每次只能在某根柱子的最上面放球. (2)在同一根柱子中,任何2个相邻球的编号之和为完全 ...

  8. 【Luogu】P2765魔术球问题(没看懂的乱搞)

    题目链接 这题……讲道理我没看懂. 不过我看懂题解的代码是在干嘛了qwq 题解是zhaoyifan的题解 然后……我来讲讲这个题解好了. 题解把值为i的球拆成了两个,一个编号是i*2,一个编号是i*2 ...

  9. 洛谷P2765 魔术球问题(贪心 最大流)

    题意 已经很简洁了吧. 假设有n根柱子,现要按下述规则在这n根柱子中依次放入编号为1,2,3,...的球. (1)每次只能在某根柱子的最上面放球. (2)在同一根柱子中,任何2个相邻球的编号之和为完全 ...

随机推荐

  1. Sql注入基础原理介绍

    说明:文章所有内容均截选自实验楼教程[Sql注入基础原理介绍]~ 实验原理 Sql 注入攻击是通过将恶意的 Sql 查询或添加语句插入到应用的输入参数中,再在后台 Sql 服务器上解析执行进行的攻击, ...

  2. DataFrame修改列名

    把Dataframe格式的列名'class1'修改为'class_label' data.rename(columns={"label":"true_label" ...

  3. Python学习笔记之装饰器原理

    def decorator(fn): def wrapper(): print("询价") fn() print("购买成功!") return wrapper ...

  4. java基础练习

    String str = "Nothing is impossible to a willing heart"; String str2 = "No cross, no ...

  5. PM2管理工具的使用

    linux上PM2可以管理服务程序,防止程序无故关闭,具有程序守护功能,自动重启服务器程序,监控程序等好处,很方便,具体自己去体会! 官网地址:  http://pm2.keymetrics.io/ ...

  6. 四 js Math数学简单使用

    //Math是全局的 //Math.PI 数学里的3.1415926.... console.log(Math.PI); //取随机数 //js提供的随机函数 Math.random() --> ...

  7. linux 下nginx

    所有的配置文件都在/etc/nginx                   (ect/nginx/nginx.conf) 下,并且每个虚拟主机已经安排在 了/etc/nginx/sites-avail ...

  8. 09 查找列表中元素,移除每个元素的空格,并查找以a或A开头并且以c结尾的所有元素

    li = ["alex"," aric","Alex","Tony","rain"]for i in ...

  9. html5-figure和figcaption元素

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  10. 解读NoSQL数据库的四大家族

    在目前的企业IT架构中,系统管理员以及DBA都会考虑使用NoSQL数据库来解决RDBMS所不能解决的问题,特别是互联网行业.传统的关系型数据库主要以表(table)的形式来存储数据,而无法应对非结构化 ...