// ~~ icebear ~~
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> ii;
typedef pair<int, ii> iii;
template<class T>
bool minimize(T &a, const T &b) {
if (a > b) return a = b, true;
return false;
}
template<class T>
bool maximize(T &a, const T &b) {
if (a < b) return a = b, true;
return false;
}
#define FOR(i,a,b) for(int i=(a); i<=(b); ++i)
#define FORR(i,a,b) for(int i=(a); i>=(b); --i)
#define REP(i, n) for(int i=0; i<(n); ++i)
#define RED(i, n) for(int i=(n)-1; i>=0; --i)
#define MASK(i) (1LL << (i))
#define BIT(S, i) (((S) >> (i)) & 1)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define all(x) x.begin(), x.end()
#define task "diduduadi"
/*END OF TEMPLATE. ICEBEAR AND THE CAT WILL WIN VOI26 */
const int MOD = 1e9 + 7;
const int inf = 1e9 + 27092008;
const ll INF = 1e18 + 27092008;
const int N = 2e5 + 5;
int n, m, q, num, T[N];
array<int, 4> Q[N];
vector<ii> people[N];
int tmp[N];
int check(int drink) {
int ans = 0, cnt = 0;
for(ii per : people[drink]) {
tmp[per.fi] = T[per.fi];
}
bool ok = false;
for(ii per : people[drink]) {
if (T[per.fi] <= per.se) ok = true;
if (T[per.fi] < inf) cnt++;
if (T[per.fi] <= inf) ans++;
T[per.fi] = inf + 1;
}
for(ii per : people[drink]) T[per.fi] = tmp[per.fi];
return (cnt == num && !ok ? ans : -1);
}
void init(void) {
cin >> n >> m >> q;
FOR(i, 1, m) people[i].clear();
FOR(i, 1, n) T[i] = inf;
num = 0;
FOR(i, 1, q) {
char t;
cin >> t;
if (t == '+') {
int per, drink, time;
cin >> per >> drink >> time;
people[drink].pb({per, time});
}
else {
int per, time;
cin >> per >> time;
T[per] = time;
num++;
}
}
}
void process(void) {
FOR(i, 1, m) sort(all(people[i]));
int ans = -1;
FOR(i, 1, m) maximize(ans, check(i));
cout << ans << ' ';
}
int main() {
ios_base::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
if (fopen(task".inp", "r")) {
freopen(task".inp", "r", stdin);
freopen(task".out", "w", stdout);
}
int subtask, tc = 1;
cin >> subtask >> tc;
while(tc--) {
init();
process();
}
return 0;
}
Ly8gfn4gaWNlYmVhciB+fgojaW5jbHVkZSA8Yml0cy9zdGRjKysuaD4KdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCnR5cGVkZWYgbG9uZyBsb25nIGxsOwp0eXBlZGVmIHBhaXI8aW50LCBpbnQ+IGlpOwp0eXBlZGVmIHBhaXI8aW50LCBpaT4gaWlpOwoKdGVtcGxhdGU8Y2xhc3MgVD4KICAgIGJvb2wgbWluaW1pemUoVCAmYSwgY29uc3QgVCAmYikgewogICAgICAgIGlmIChhID4gYikgcmV0dXJuIGEgPSBiLCB0cnVlOwogICAgICAgIHJldHVybiBmYWxzZTsKICAgIH0KCnRlbXBsYXRlPGNsYXNzIFQ+CiAgICBib29sIG1heGltaXplKFQgJmEsIGNvbnN0IFQgJmIpIHsKICAgICAgICBpZiAoYSA8IGIpIHJldHVybiBhID0gYiwgdHJ1ZTsKICAgICAgICByZXR1cm4gZmFsc2U7CiAgICB9CgojZGVmaW5lIEZPUihpLGEsYikgZm9yKGludCBpPShhKTsgaTw9KGIpOyArK2kpCiNkZWZpbmUgRk9SUihpLGEsYikgZm9yKGludCBpPShhKTsgaT49KGIpOyAtLWkpCiNkZWZpbmUgUkVQKGksIG4pIGZvcihpbnQgaT0wOyBpPChuKTsgKytpKQojZGVmaW5lIFJFRChpLCBuKSBmb3IoaW50IGk9KG4pLTE7IGk+PTA7IC0taSkKI2RlZmluZSBNQVNLKGkpICgxTEwgPDwgKGkpKQojZGVmaW5lIEJJVChTLCBpKSAoKChTKSA+PiAoaSkpICYgMSkKI2RlZmluZSBtcCBtYWtlX3BhaXIKI2RlZmluZSBwYiBwdXNoX2JhY2sKI2RlZmluZSBmaSBmaXJzdAojZGVmaW5lIHNlIHNlY29uZAojZGVmaW5lIGFsbCh4KSB4LmJlZ2luKCksIHguZW5kKCkKI2RlZmluZSB0YXNrICJkaWR1ZHVhZGkiCi8qRU5EIE9GIFRFTVBMQVRFLiBJQ0VCRUFSIEFORCBUSEUgQ0FUIFdJTEwgV0lOIFZPSTI2ICovCgpjb25zdCBpbnQgTU9EID0gMWU5ICsgNzsKY29uc3QgaW50IGluZiA9IDFlOSArIDI3MDkyMDA4Owpjb25zdCBsbCBJTkYgPSAxZTE4ICsgMjcwOTIwMDg7CmNvbnN0IGludCBOID0gMmU1ICsgNTsKaW50IG4sIG0sIHEsIG51bSwgVFtOXTsKYXJyYXk8aW50LCA0PiBRW05dOwp2ZWN0b3I8aWk+IHBlb3BsZVtOXTsKaW50IHRtcFtOXTsKCmludCBjaGVjayhpbnQgZHJpbmspIHsKICAgIGludCBhbnMgPSAwLCBjbnQgPSAwOwogICAgZm9yKGlpIHBlciA6IHBlb3BsZVtkcmlua10pIHsKICAgICAgICAgIHRtcFtwZXIuZmldID0gVFtwZXIuZmldOwogICAgIH0KICAgICBib29sIG9rID0gZmFsc2U7CiAgICBmb3IoaWkgcGVyIDogcGVvcGxlW2RyaW5rXSkgewogICAgICAgIGlmIChUW3Blci5maV0gPD0gcGVyLnNlKSBvayA9IHRydWU7CiAgICAgICAgaWYgKFRbcGVyLmZpXSAgPCBpbmYpIGNudCsrOwogICAgICAgIGlmIChUW3Blci5maV0gPD0gaW5mKSBhbnMrKzsKICAgICAgICBUW3Blci5maV0gPSBpbmYgKyAxOwogICAgfQogICAgZm9yKGlpIHBlciA6IHBlb3BsZVtkcmlua10pIFRbcGVyLmZpXSA9IHRtcFtwZXIuZmldOwogICAgcmV0dXJuIChjbnQgPT0gbnVtICYmICFvayA/IGFucyA6IC0xKTsKfQoKdm9pZCBpbml0KHZvaWQpIHsKICAgIGNpbiA+PiBuID4+IG0gPj4gcTsKICAgIEZPUihpLCAxLCBtKSBwZW9wbGVbaV0uY2xlYXIoKTsKICAgIEZPUihpLCAxLCBuKSBUW2ldID0gaW5mOwogICAgbnVtID0gMDsKICAgIEZPUihpLCAxLCBxKSB7CiAgICAgICAgY2hhciB0OwogICAgICAgIGNpbiA+PiB0OwogICAgICAgIGlmICh0ID09ICcrJykgewogICAgICAgICAgICBpbnQgcGVyLCBkcmluaywgdGltZTsKICAgICAgICAgICAgY2luID4+IHBlciA+PiBkcmluayA+PiB0aW1lOwogICAgICAgICAgICBwZW9wbGVbZHJpbmtdLnBiKHtwZXIsIHRpbWV9KTsKICAgICAgICB9CiAgICAgICAgZWxzZSB7CiAgICAgICAgICAgIGludCBwZXIsIHRpbWU7CiAgICAgICAgICAgIGNpbiA+PiBwZXIgPj4gdGltZTsKICAgICAgICAgICAgVFtwZXJdID0gdGltZTsKICAgICAgICAgICAgbnVtKys7CiAgICAgICAgfQogICAgfQp9Cgp2b2lkIHByb2Nlc3Modm9pZCkgewogICAgRk9SKGksIDEsIG0pIHNvcnQoYWxsKHBlb3BsZVtpXSkpOwogICAgaW50IGFucyA9IC0xOwogICAgRk9SKGksIDEsIG0pIG1heGltaXplKGFucywgY2hlY2soaSkpOwogICAgY291dCA8PCBhbnMgPDwgJyAnOwp9CgppbnQgbWFpbigpIHsKICAgIGlvc19iYXNlOjpzeW5jX3dpdGhfc3RkaW8oMCk7CiAgICBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKICAgIGlmIChmb3Blbih0YXNrIi5pbnAiLCAiciIpKSB7CiAgICAgICAgZnJlb3Blbih0YXNrIi5pbnAiLCAiciIsIHN0ZGluKTsKICAgICAgICBmcmVvcGVuKHRhc2siLm91dCIsICJ3Iiwgc3Rkb3V0KTsKICAgIH0KICAgIGludCBzdWJ0YXNrLCB0YyA9IDE7CiAgICBjaW4gPj4gc3VidGFzayA+PiB0YzsKICAgIHdoaWxlKHRjLS0pIHsKICAgICAgICBpbml0KCk7CiAgICAgICAgcHJvY2VzcygpOwogICAgfQogICAgcmV0dXJuIDA7Cn0=