#286. 机器任务

机器任务

题目描述

有两台机器 AB\red {A,B} 以及 K\red {K} 个任务。

机器 A\red {A}N\red {N} 种不同的模式(模式0N1\red {0\sim N-1}),机器 B\red {B}M\red {M} 种不同的模式(模式0M1\red {0\sim M-1})。

两台机器最开始都处于模式0\red {0}

每个任务既可以在A\red {A}上执行,也可以在B\red {B}上执行。

对于每个任务 i\red {i},给定两个整数 a[i]\red {a[i]}b[i]\red {b[i]},表示如果该任务在 A\red {A} 上执行,需要设置模式为a[i]\red { a[i]},如果在B\red { B} 上执行,需要模式为 b[i]\red {b[i]}

任务可以以任意顺序被执行,但每台机器转换一次模式就要重启一次。

求怎样分配任务并合理安排顺序,能使机器重启次数最少。

输入格式

输入包含多组测试数据。

每组数据第一行包含三个整数 N,M,K\red {N, M, K}

接下来k\red {k}行,每行三个整数 i,a[i]\red {i, a[i]}b[i]i\red {b[i],i }为任务编号,从0\red {0}开始。

当输入一行为0\red {0}时,表示输入终止。

输出格式

每组数据输出一个整数,表示所需的机器最少重启次数,每个结果占一行。

样例

输入样例

5 5 10
0 1 1
1 1 2
2 1 3
3 1 4
4 2 1
5 2 2
6 2 3
7 2 4
8 3 3
9 4 3
0

输出样例

3

提示

N,M<100,K<1000\red {N,M<100,K<1000}

0a[i]<N\red {0≤a[i]<N}

0b[i]<M\red {0≤b[i]<M}