← Home
package main

import (
	"bufio"
	"fmt"
	"os"
)

type FastScanner struct {
	r *bufio.Reader
}

func NewFastScanner() *FastScanner {
	return &FastScanner{r: bufio.NewReaderSize(os.Stdin, 1<<20)}
}

func (fs *FastScanner) NextInt64() int64 {
	var sign int64 = 1
	var val int64
	c, _ := fs.r.ReadByte()
	for (c < '0' || c > '9') && c != '-' {
		c, _ = fs.r.ReadByte()
	}
	if c == '-' {
		sign = -1
		c, _ = fs.r.ReadByte()
	}
	for c >= '0' && c <= '9' {
		val = val*10 + int64(c-'0')
		c2, err := fs.r.ReadByte()
		if err != nil {
			return sign * val
		}
		c = c2
	}
	_ = fs.r.UnreadByte()
	return sign * val
}

func main() {
	in := NewFastScanner()
	out := bufio.NewWriterSize(os.Stdout, 1<<20)
	defer out.Flush()

	T := int(in.NextInt64())
	for ; T > 0; T-- {
		N := in.NextInt64()
		M := int(in.NextInt64())
		K := int(in.NextInt64())

		mod := K + 1
		x := make([]int, mod)

		for i := 0; i < M; i++ {
			R := in.NextInt64()
			_ = in.NextInt64() // C is irrelevant
			A := int(in.NextInt64())

			v := A % mod
			if v == 0 {
				continue
			}
			cls := int((N - R) % int64(mod))
			x[cls] ^= v
		}

		win := false
		for i := 0; i < mod; i++ {
			if x[i] != 0 {
				win = true
				break
			}
		}

		if win {
			fmt.Fprintln(out, "Anda")
		} else {
			fmt.Fprintln(out, "Kamu")
		}
	}
}