BZOJ-1202 狡猾的商人 并查集+前缀和
我记得这个题,上次之前做的时候没改完,撂下了,今天突然想改发现,woc肿么A 了= =看来是我记错了。。
1202: [HNOI2005]狡猾的商人 
Time Limit: 10 Sec  Memory Limit: 162 MB 
Submit: 2232  Solved: 1060 
[Submit][Status][Discuss]
Description 
刁姹接到一个任务,为税务部门调查一位商人的账本,看看账本是不是伪造的。账本上记录了n个月以来的收入情况,其中第i 个月的收入额为Ai(i=1,2,3…n-1,n), 。当 Ai大于0时表示这个月盈利Ai 元,当 Ai小于0时表示这个月亏损Ai 元。所谓一段时间内的总收入,就是这段时间内每个月的收入额的总和。 刁姹的任务是秘密进行的,为了调查商人的账本,她只好跑到商人那里打工。她趁商人不在时去偷看账本,可是她无法将账本偷出来,每次偷看账本时她都只能看某段时间内账本上记录的收入情况,并且她只能记住这段时间内的总收入。 现在,刁姹总共偷看了m次账本,当然也就记住了m段时间内的总收入,你的任务是根据记住的这些信息来判断账本是不是假的。
Input 
第一行为一个正整数w,其中w < 100,表示有w组数据,即w个账本,需要你判断。每组数据的第一行为两个正整数n和m,其中n < 100,m < 1000,分别表示对应的账本记录了多少个月的收入情况以及偷看了多少次账本。接下来的m行表示刁姹偷看m次账本后记住的m条信息,每条信息占一行,有三个整数s,t和v,表示从第s个月到第t个月(包含第t个月)的总收入为v,这里假设s总是小于等于t。
Output 
包含w行,每行是true或false,其中第i行为true当且仅当第i组数据,即第i个账本不是假的;第i行为false当且仅当第i组数据,即第i个账是假的。
Sample Input 
2 
3 3 
1 2 10 
1 3 -5 
3 3 -15 
5 3 
1 5 100 
3 5 50 
1 2 51
Sample Output 
true  
false
HINT
Source
并查集+前缀和维护。似乎没什么好说的。。。(其实做的太早似乎快忘 了。。)
code:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int father[10000]={0};
int dis[10000]={0};
bool flag=true;
int w,n,m;
int x,y,z;
int find(int x)
{
  if (father[x]==x)
   return x;
  int temp=find(father[x]);
  dis[x]+=dis[father[x]];
  father[x]=temp;
  return father[x];
}
void merge(int x,int y)
{
    int f1=find(x);
    int f2=find(y);
    if (f1!=f2)
     {
        father[f1]=f2;
        dis[f1]=dis[y]-dis[x]-z;
     }
    else
     if (dis[y]-dis[x]!=z)
      flag=false;
}
int main()
{
    scanf("%d",&w);
    for (int t=1;t<=w;t++)
     {
        scanf("%d%d",&n,&m);
        for (int i=0;i<=n;i++)
         father[i]=i;
        memset(dis,0,sizeof(dis));
        flag=true;
        for (int i=1;i<=m;i++)
         {
            scanf("%d%d%d",&x,&y,&z);
            merge(x-1,y);
         }
        if (flag)
         printf("%s\n","true");
        else
         printf("%s\n","false");
     }
  return 0;
}BZOJ-1202 狡猾的商人 并查集+前缀和的更多相关文章
- BZOJ 1202 狡猾的商人 差分约束or带权并查集
		题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1202 题目大意: 刁姹接到一个任务,为税务部门调查一位商人的账本,看看账本是不是伪造的 ... 
- bzoj 1202: [HNOI2005]狡猾的商人 并查集好题
		1202: [HNOI2005]狡猾的商人 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2946 Solved: 1384[Submit][Sta ... 
- BZOJ 1202 狡猾的商人(带权并查集)
		给出了l,r,w.我们就得知了s[r]-s[l-1]=w.也就是说,点l-1和点r的距离为w. 于是可以使用带权并查集,定义dis[i]表示点i到根节点的距离.查询和合并的时候维护一下就OK了. 如果 ... 
- bzoj1202: [HNOI2005]狡猾的商人(并查集  差分约束)
		1202: [HNOI2005]狡猾的商人 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4127 Solved: 1981[Submit][Sta ... 
- BZOJ1202  [HNOI2005]狡猾的商人  并查集维护前缀和
		1202: [HNOI2005]狡猾的商人 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1935 Solved: 936[Submit][Stat ... 
- B1202 [HNOI2005]狡猾的商人 并查集
		其实就是并查集的题.维护一个前缀和,然后用并查集维护前缀和,每次判断是否合理就行了. 题干: Description 刁姹接到一个任务,为税务部门调查一位商人的账本,看看账本是不是伪造的.账本上记录了 ... 
- BZOJ 1202 狡猾的商人
		前缀和+带权并查集. #include<iostream> #include<cstdio> #include<cstring> #include<algor ... 
- 【BZOJ】1202: [HNOI2005]狡猾的商人(并查集+前缀和)
		http://www.lydsy.com/JudgeOnline/problem.php?id=1202 用并查集+前缀和. 前缀和从后向前维护和,并查集从前往后合并 对于询问l, r 如果l-1和r ... 
- 【bzoj 1202】[HNOI2005] 狡猾的商人(图论--带权并查集+前缀和)
		题意:一个账本记录了N个月以来的收入情况,现在有一个侦探员不同时间偷看到M段时间内的总收入,问这个账本是否为假账. 解法:带权并查集+前缀和. 判断账本真假是通过之前可算到的答案与当前读入的值是否 ... 
随机推荐
- Android安全机制(2) Android Permission权限控制机制
			http://blog.csdn.net/vshuang/article/details/44001661 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 1.概述 Andro ... 
- ubuntu手贱改了sudoers权限之后的恢复
			sudo 这个命令是ubuntu系统是用的最多的(和其他大众版linux系统比起来),而一个普通用户是否有sudo权限来临时切换到root用户来执行“一行”命令取决于 /etc/sudoers的配置, ... 
- MString 与 QString 互转
			MQtUtil static MString toMString (const QString &qstr) Convenience utility to convert a QStri ... 
- 利用exif.js解决ios手机上传竖拍照片旋转90度问题
			html5+canvas进行移动端手机照片上传时,发现ios手机上传竖拍照片会逆时针旋转90度,横拍照片无此问题:Android手机没这个问题. 因此解决这个问题的思路是:获取到照片拍摄的方向角,对非 ... 
- usb驱动开发6之端点描述符
			学到这里不容易,先说一段故事吧. 二兄弟住一大楼的第80层,某深夜回家忘看通知(内容今夜停电). 兄弟俩背着沉重的大背包,在楼底下商量一下,决定一鼓作气,爬楼梯回家.两人抖擞精神,开始爬楼.爬到20楼 ... 
- ESLint 检查代码质量
			利用 ESLint 检查代码质量 其实很早的时候就想尝试 ESLint 了,但是很多次都是玩了一下就觉得这东西巨复杂,一执行检查就是满屏的error,简直是不堪入目,遂放弃.直到某天终于下定决心深入看 ... 
- 专门用于微信公众平台的Javascript API
			1 /**! 2 * 微信内置浏览器的Javascript API,功能包括: 3 * 4 * 1.分享到微信朋友圈 5 * 2.分享给微信好友 6 * 3.分享到腾讯微博 7 * 4.新的分享接口, ... 
- Android 动画之ScaleAnimation应用详解
			本节讲解ScaleAnimation 动画, ScaleAnimation(float fromX, float toX, float fromY, float toY,int pivotXType, ... 
- Android -- 创建数据库到SD卡
			SQLite 系统自带的SQLite是通过SQLiteOpenHelper实现的,而SQLiteOpenHelper是将数据库存储到/data/data/包名/databasas,这样做的话在没有ro ... 
- Android权限列表permission说明
			网络上不乏android权限列表,但是很少有将列表和使用方法放在一起的,所以特此总结一下 需要在AndroidManifest.xml中定义相应的权限(以获取internet访问权限为例),如下: & ... 
