bzoj1603: [Usaco2008 Oct]打谷机 (纱布题)

Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 774  Solved: 593 [Submit][Status][Discuss]

Description

Farmer John有一个过时的打谷机(收割小麦),它需要带子来带动。发动机驱动轮1总是顺时针旋转的,用来带动转轮2,转轮2来带动转轮3,等等。一共有n(2<=n<=1000)个转轮(n-1条带子)。上面的图解描述了转轮的两种连接方式,第一种方式使得两个轮子旋转的方向相同,第二种则相反。 给出一串带子的信息: *Si—驱动轮 *Di—被动轮 *Ci—连接的类型(0=直接连接,1=交叉连接) 不幸的是,列出的信息是随即的。 作为样例,考虑上面的图解,n=4,转轮1是驱动轮,可以得知最后转轮4是逆时针旋转的。

Input

*第一行:一个数n *第二行到第n行:每一行有三个被空格隔开的数:Si,Di,Ci

Output

*第一行:一个单独的数,表示第n个转轮的方向,0表示顺时针,1表示逆时针。

Sample Input

4 2 3 0 3 4 1 1 2 0

Sample Output

1

思路:傻逼模拟题。。。。排下序。

 1/* ***********************************************
 2Author :111qqz
 3Created Time :2016年03月31日 星期四 21时04分09秒
 4File Name :code/bzoj/1603.cpp
 5************************************************ */
 6
 7#include <cstdio>
 8#include <cstring>
 9#include <iostream>
10#include <algorithm>
11#include <vector>
12#include <queue>
13#include <set>
14#include <map>
15#include <string>
16#include <cmath>
17#include <cstdlib>
18#include <ctime>
19#define fst first
20#define sec second
21#define lson l,m,rt<<1
22#define rson m+1,r,rt<<1|1
23#define ms(a,x) memset(a,x,sizeof(a))
24typedef long long LL;
25#define pi pair < int ,int >
26#define MP make_pair
27
28using namespace std;
29const double eps = 1E-8;
30const int dx4[4]={1,0,0,-1};
31const int dy4[4]={0,-1,1,0};
32const int inf = 0x3f3f3f3f;
33const int N=1005;
34int n;
35
36struct node
37{
38    int s,d,c;
39
40    bool operator < (node b)const
41    {
42	return s<b.s;
43    }
44}a[N];
45int main()
46{
47	#ifndef  ONLINE_JUDGE 
48	freopen("code/in.txt","r",stdin);
49  #endif
50	cin>>n;
51	for  ( int i = 1 ; i <= n-1 ; i ++) cin>>a[i].s>>a[i].d>>a[i].c;
52
53	sort(a+1,a+n);
54	int flag = 0;
55	for ( int i = 1 ;i  <= n-1 ; i++)
56	{
57	    if (a[i].c==1) flag^=1;
58	}
59	cout<<flag<<endl;
60
61  #ifndef ONLINE_JUDGE  
62  fclose(stdin);
63  #endif
64    return 0;
65}