小K的农场


  1. 题目描述
  2. KMC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三种形式描述:
  3. 农场a比农场b至少多种植了c个单位的作物,
  4. 农场a比农场b至多多种植了c个单位的作物,
  5. 农场a与农场b种植的作物数一样多。
  6. 但是,由于小K的记忆有些偏差,所以他想要知道存不存在一种情况,使得农场的种植作物数量与他记忆中的所有信息吻合。
  7. 输入输出格式
  8. 输入格式:
  9. 第一行包括两个整数 n m,分别表示农场数目和小 K 记忆中的信息数目。
  10. 接下来 m 行:
  11. 如果每行的第一个数是 1,接下来有 3 个整数 a,b,c,表示农场 a 比农场 b 至少多种植了 c 个单位的作物。
  12. 如果每行的第一个数是 2,接下来有 3 个整数 a,b,c,表示农场 a 比农场 b 至多多种植了 c 个单位的作物。如果每行的第一个数是 3,接下来有 2 个整数 a,b,表示农场 a 种植的的数量和 b 一样多。
  13. 输出格式:
  14. 如果存在某种情况与小 K 的记忆吻合,输出“Yes”,否则输出“No”。
  15. 输入输出样例
  16. 输入样例#1
  17. 3 3
  18. 3 1 2
  19. 1 1 3 1
  20. 2 2 3 2
  21. 输出样例#1
  22. Yes
  23. 说明
  24. 对于 100% 的数据保证:1 nmabc 10000

差分约束可以求解最短路和最长路。这道题也是差分约束的模板题。

根据:

  1. 农场a比农场b至少多种植了c个单位的作物,
  2. 农场a比农场b至多多种植了c个单位的作物,
  3. 农场a与农场b种植的作物数一样多。

建立条件。

由题可知,农场a比农场b至少多种植了c个单位的作物,所以Xa-Xb>=cXb-Xa<=-c, 农场a比农场b至多多种植了c个单位的作物,所以Xa-Xb<=c,农场a与农场b种植的作物数一样多,所以Xa==Xb,则Xa-Xb<=cXb-Xa<=c

然后用SPFA。(不要连错了权值)

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn=11000;
  4. const int inf=0x3f3f3f3f;
  5. int n,m;
  6. struct node{
  7. int v,w;
  8. node(){ }
  9. node(int _v,int _w){
  10. v=_v;
  11. w=_w;
  12. }
  13. };
  14. vector <node> g[maxn];
  15. int dst[maxn];
  16. queue <int> qu;
  17. bool inq[maxn];
  18. int cnt[maxn];
  19. int add(int u,int v,int w){
  20. g[u].push_back(node(v,w));
  21. }
  22. bool spfa(int u){
  23. memset(dst,inf,sizeof dst);
  24. // memset(cnt,0,sizeof cnt);
  25. dst[u]=0;
  26. qu.push(u);
  27. inq[u]=1;
  28. while(!qu.empty()){
  29. u=qu.front();
  30. qu.pop();
  31. inq[u]=0;
  32. for(int i=0;i<g[u].size();i++){
  33. int v=g[u][i].v;
  34. int w=g[u][i].w;
  35. if(dst[v]>dst[u]+w){
  36. dst[v]=dst[u]+w;
  37. if(!inq[v]){
  38. qu.push(v);
  39. inq[v]=1;
  40. cnt[v]++;
  41. if(cnt[v]>n){
  42. return 0;
  43. }
  44. }
  45. }
  46. }
  47. }
  48. return 1;
  49. }
  50. int main(){
  51. cin >> n >> m;
  52. for(int i=1;i<=n;i++){
  53. add(0,i,0);
  54. }
  55. for(int i=0;i<m;i++){
  56. int d,a,b,c;
  57. cin >> d;
  58. if(d==1){
  59. cin >>a>>b>>c;
  60. g[a].push_back(node(b,-c));
  61. }else if(d==2){
  62. cin >>a>>b>>c;
  63. g[b].push_back(node(a,c));
  64. }else{
  65. cin >>a>>b;
  66. g[a].push_back(node(b,0));
  67. g[b].push_back(node(a,0));
  68. }
  69. }
  70. if(spfa(0)){
  71. cout << "Yes";
  72. }else{
  73. cout << "No";
  74. }
  75. return 0;
  76. }

但实际上,它只能得到60分。四组TLE。。。

于是,就涉及到另外一个数据结构,双向队列。双向队列有队列和栈的性质。可以从两端入队,弹出。在这道题里,我们用if判断,在队列后端放入较大的值,前端放入较小的值分别用back和front访问最后一个元素和第一个元素。

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn=11000;
  4. const int inf=0x3f3f3f3f;
  5. int n,m;
  6. struct node{
  7. int v,w;
  8. node(){ }
  9. node(int _v,int _w){
  10. v=_v;
  11. w=_w;
  12. }
  13. };
  14. vector <node> g[maxn];
  15. int dst[maxn];
  16. deque<int> qu;//双向队列
  17. bool inq[maxn];
  18. int cnt[maxn];
  19. int add(int u,int v,int w){
  20. g[u].push_back(node(v,w));
  21. }
  22. bool spfa(int u){
  23. memset(dst,inf,sizeof dst);//初始化
  24. // memset(cnt,0,sizeof cnt);
  25. dst[u]=0;
  26. qu.push_back(u);//双向队列的访问最后一个元素写法
  27. inq[u]=1;
  28. while(!qu.empty()){
  29. u=qu.front();//双向队列的访问第一个元素写法
  30. qu.pop_front();
  31. if(dst[qu.front()]>dst[qu.back()]){
  32. swap(qu.front(),qu.back());//交换
  33. }
  34. inq[u]=0;
  35. for(int i=0;i<g[u].size();i++){
  36. int v=g[u][i].v;
  37. int w=g[u][i].w;
  38. if(dst[v]>dst[u]+w){
  39. dst[v]=dst[u]+w;
  40. if(!inq[v]){
  41. if(dst[v]<dst[qu.front()]){//判断,比较大小
  42. qu.push_front(v);//插入队首
  43. }else{
  44. qu.push_back(v);//插入队尾
  45. }
  46. inq[v]=1;
  47. cnt[v]++;
  48. if(cnt[v]>n){
  49. return 0;
  50. }
  51. }
  52. }
  53. }
  54. }
  55. return 1;
  56. }
  57. int main(){
  58. cin >> n >> m;
  59. for(int i=1;i<=n;i++){
  60. add(0,i,0);
  61. }
  62. for(int i=0;i<m;i++){
  63. int d,a,b,c;
  64. cin >> d;
  65. if(d==1){//连权值
  66. cin >>a>>b>>c;
  67. g[a].push_back(node(b,-c));
  68. }else if(d==2){
  69. cin >>a>>b>>c;
  70. g[b].push_back(node(a,c));
  71. }else{
  72. cin >>a>>b;
  73. g[a].push_back(node(b,0));
  74. g[b].push_back(node(a,0));
  75. }
  76. }
  77. if(spfa(0)){
  78. cout << "Yes";
  79. }else{
  80. cout << "No";
  81. }
  82. return 0;
  83. }

P1993 小K的农场(差分约束)的更多相关文章

  1. P1993 小K的农场 && 差分约束

    首先第一篇讨论的是差分约束系统解的存在 差分约束系统是有 \(n\) 个变量及 \(m\) 个(如 \(x_{i} - x_{j} \leq a_{k}\) )关系组成的系统 差分约束解的求解可以转化 ...

  2. 洛谷P1993 小K的农场 [差分约束系统]

    题目传送门 小K的农场 题目描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三种形式描述: 农场a比农场b ...

  3. 【BZOJ3436】小K的农场 差分约束

    [BZOJ3436]小K的农场 Description 背景 小K是个特么喜欢玩MC的孩纸... 描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了, ...

  4. P1993 小K的农场 差分约束系统

    这个题是一道差分约束系统的裸题,什么是差分约束系统呢?就是给了一些大小条件,然后让你找一个满足的图.这时就要用差分约束了. 怎么做呢?其实很简单,就是直接建图就好,但是要把所有条件变为小于等于号,假如 ...

  5. 小K的农场 差分约束

    题目描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三种形式描述: 农场a比农场b至少多种植了c个单位的作 ...

  6. BZOJ 3436: 小K的农场 差分约束

    题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=3436 题解: 裸的差分约束: 1.a>=b+c  ->  b<=a-c ...

  7. P1993 小K的农场

    P1993 小K的农场比较裸的差分约束,只是我判负环的时候sb了... 有负环意味着无解 #include<iostream> #include<cstdio> #includ ...

  8. 洛谷 P1993 小K的农场 解题报告

    P1993 小K的农场 题目描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三种形式描述: 农场a比农场b ...

  9. 洛谷 P1993 小K的农场

    P1993 小K的农场 题目描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三种形式描述: 农场a比农场b ...

随机推荐

  1. 服务器上build.xml文件乱码解决(亲测有效)

    前提条件:必须root账户登录系统,否则无权限 1. 修改/etc/sysconfig/i18n: 拷贝如下内容到文件中 #LANG="zh_CN.UTF-8" LANG=&quo ...

  2. App弱网测试与常用模拟工具

    iOS平台,通过自带的开发者选项 >Network Link Conditioner, 即可简单的模拟各种速度的网络情况: 通过抓包工具,设置延迟,进行模拟不同的网络情况,比如常用的fiddle ...

  3. 用avalon框架怎么做轮播图?

    avalon这个框架其实特别的小众,做个轮播图呢?在github上的例子只有一个,而且功能特别的少,有的引入的插件与avalon里面的指令又不兼容,所以找了一个owl-carousel,目前实现了移动 ...

  4. Ubuntu16.04忘记MySQL5.7的root用户密码之解决方案

    其实也就四步,如下: 修改配置文件 sudo vimi /etc/mysql/mysql.conf.d/mysqld.cnf 并在 在[mysqld]下方的skip-external-locking下 ...

  5. select,poll,epoll最简单的解释

    从事服务端开发,少不了要接触网络编程.epoll 作为 Linux 下高性能网络服务器的必备技术至关重要,nginx.Redis.Skynet 和大部分游戏服务器都使用到这一多路复用技术. epoll ...

  6. 聊聊SSH框架

    目录 前期准备工作 jrebel(热加载,后台会自动帮忙部署项目) lombok(根据字段,自动生成对应的set和get方法) log4j(日志打印) 所需jar包 log4j2.xml log4j. ...

  7. idea 启动web项目

    1>Run>Edit Configurations... 2>Server>Open browser>URL>http://localhost:8888/demo2 ...

  8. MiniUI表单验证总结

    原文地址:https://www.cnblogs.com/wllcs/p/5607890.html 1,页面效果图 2,代码实现   <!DOCTYPE html PUBLIC "-/ ...

  9. Kali Linux软件更新日报20190623

    Kali Linux软件更新日报20190623   (1)payloadsallthethings更新到2.0-0kali4,此次更新增加帮助脚本. (2)tftpd32更新到4.50-0kali2 ...

  10. Android点击事件通过kotlin几种实现方式总结

    一般来说,Android点击事件通过kotlin有以下几种实现方式: 1.通过全局接口View.OnClickListener实现,代码如下 //class MainActivity : AppCom ...