#define _CRT_SECURE_NO_WARNINGS
#include <cstdio>
#include <vector>
#include <functional>
#include <string>
#include <algorithm>
#include <set>
#include <map>
#include <set>
#include <cstdlib>
#include <cassert>
#include <unordered_map>
#include <unordered_set>
#include <queue>
#include <numeric>
#include <deque>
#include <random>
#include <chrono>
#include <ctime>
#include <climits>
#include <stack>
#include <array>
#include <iomanip>
#include <complex>
#include <bitset>
#include <iostream>
#include <cstring>
using namespace std;
using ll = long long;
using ld = double;
#define n_l '\n'
#define dbg(...) cout << "[" << #__VA_ARGS__ << "]: "; cout << to_string(__VA_ARGS__) << endl
template <typename T, size_t N> int SIZE(const T(&t)[N]) { return N; } template<typename T> int SIZE(const T &t) { return t.size(); } string to_string(const string s, int x1 = 0, int x2 = 1e9) { return '"' + ((x1 < s.size()) ? s.substr(x1, x2 - x1 + 1) : "") + '"'; } string to_string(const char* s) { return to_string((string)s); } string to_string(const bool b) { return (b ? "true" : "false"); } string to_string(const char c) { return string({ c }); } template<size_t N> string to_string(const bitset<N> &b, int x1 = 0, int x2 = 1e9) { string t = ""; for (int __iii__ = min(x1, SIZE(b)), __jjj__ = min(x2, SIZE(b) - 1); __iii__ <= __jjj__; ++__iii__) { t += b[__iii__] + '0'; } return '"' + t + '"'; } template <typename A, typename... C> string to_string(const A(&v), int x1 = 0, int x2 = 1e9, C... coords); int l_v_l_v_l = 0, t_a_b_s = 0; template <typename A, typename B> string to_string(const pair<A, B> &p) { l_v_l_v_l++; string res = "(" + to_string(p.first) + ", " + to_string(p.second) + ")"; l_v_l_v_l--; return res; } template <typename A, typename... C> string to_string(const A(&v), int x1, int x2, C... coords) { int rnk = rank<A>::value; string tab(t_a_b_s, ' '); string res = ""; bool first = true; if (l_v_l_v_l == 0) res += n_l; res += tab + "["; x1 = min(x1, SIZE(v)), x2 = min(x2, SIZE(v)); auto l = begin(v); advance(l, x1); auto r = l; advance(r, (x2 - x1) + (x2 < SIZE(v))); for (auto e = l; e != r; e = next(e)) { if (!first) { res += ", "; } first = false; l_v_l_v_l++; if (e != l) { if (rnk > 1) { res += n_l; t_a_b_s = l_v_l_v_l; }; } else { t_a_b_s = 0; } res += to_string(*e, coords...); l_v_l_v_l--; } res += "]"; if (l_v_l_v_l == 0) res += n_l; return res; } void dbgm() { ; } template<typename Heads, typename... Tails> void dbgm(Heads H, Tails... T) { cout << to_string(H) << " | "; dbgm(T...); }
#define dbgm(...) cout << "[" << #__VA_ARGS__ << "]: "; dbgm(__VA_ARGS__); cout << endl
//#define FAST_ALLOCATOR_MEMORY 2e8
#ifdef FAST_ALLOCATOR_MEMORY // 2e8
int allocator_pos = 0;
char allocator_memory[(int)FAST_ALLOCATOR_MEMORY];
inline void * operator new (size_t n) {
char *res = allocator_memory + allocator_pos;
allocator_pos += n;
assert(allocator_pos <= (int)FAST_ALLOCATOR_MEMORY);
return (void *)res;
}
inline void operator delete (void *) noexcept { }
//inline void * operator new [] ( size_t ) { assert(0); }
//inline void operator delete [] ( void * ) { assert(0); }
#endif
bool DEBUGGING = 0;
#define all(a) a.begin(), a.end()
#define pii pair<int, int>
#define len(a) (int)a.size()
#define pb push_back
#define eb emplace_back
#define em emplace
#define y0 withindarkness
#define y1 apinklotusbloomed
#define yn carryingapurplesoul
#define j1 togetherformingtheTeam
/*Всё,
пиздуй-бороздуй, и я попиздил, нахуй*/
void useiostream() {
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cerr.tie(0);
}
void drop(char const *bu) {
printf("%s", bu);
exit(0);
}
ll gcd(ll a, ll b) {
return b == 0 ? a : gcd(b, a % b);
}
ll lcm(ll a, ll b) {
return a / gcd(a, b)*b;
}
ld const pi = acos(-1.0);
ld const eps = 0.000000001;
template<typename T, typename TT> bool mi(T &a, TT b) { return a > b ? (a = b, true) : false; }
template<typename T, typename TT> bool ma(T &a, TT b) { return a < b ? (a = b, true) : false; }
mt19937 ran(time(0));
int const mod = (int)1e9 + 9;
int bp(int a, int p) {
int re = 1;
while (p) {
if (p & 1)re = (re *1LL* a) % mod;
p >>= 1;
a = (a *1LL * a) % mod;
}
return re;
}
int inv(int a) {
return bp(a, mod - 2);
}
int n, m;
int arr[505][505][15];
int cnt[505][15];
int main() {
#ifdef _DEBUG
DEBUGGING = 1;
freopen("input.txt", "r", stdin);
freopen("output.txt", "w", stdout);
#else
//freopen("points.in", "r", stdin);
//freopen("points.out", "w", stdout);
#endif
useiostream();
cin >> n >> m;
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
int a;
cin >> a;
for (int k = 0; k < 10; k++) {
arr[i][j][k] = ((a & (1 << k)) != 0);
cnt[i][k]+= arr[i][j][k];
}
}
}
for (int k = 0; k < 10; k++) {
vector<int> ps(n);
vector<int> res(n);
for (int i = 0; i < n; i++)ps[i] = i;
sort(all(ps), [&](int l, int r) {return cnt[l][k] > cnt[r][k]; });
int ct = 0;
int last = -1;
for (int i = 0; i < n; i++) {
if (cnt[ps[i]][k] == m) {
ct++;
last = i;
}
}
if (ct & 1) {
cout << "TAK\n";
for (int i = 0; i <= last; i++) {
res[ps[i]] = 1;
}
for (int i = last + 1; i < n; i++) {
for (int j = 0; j < m; j++) {
if (arr[ps[i]][j][k] == 0)res[ps[i]] = j + 1;
}
}
for (int i = 0; i < n; i++) {
cout << res[i] << " ";
}
return 0;
}
else {
for (int i = last + 1; i < n && (ct % 2 )== 0; i++) {
if (cnt[ps[i]][k]) {
for (int j = 0; j < m; j++)if (arr[ps[i]][j][k]) {
ct++;
break;
}
}
}
if (ct & 1) {
cout << "TAK\n";
for (int i = 0; i <= last; i++) {
res[ps[i]] = 1;
}
bool got = 0;
for (int i = last + 1; i < n; i++) {
if (cnt[ps[i]][k] && !got) {
got = 1;
for (int j = 0; j < m; j++)if (arr[ps[i]][j][k])res[ps[i]] = j + 1;
}
else {
for (int j = 0; j < m; j++)if (arr[ps[i]][j][k] == 0)res[ps[i]] = j + 1;
}
}
for (int i = 0; i < n; i++) {
cout << res[i] << " ";
}
return 0;
}
}
}
cout << "NIE";
return 0;
}
﻿#define _CRT_SECURE_NO_WARNINGS
#include <cstdio>
#include <vector>
#include <functional>
#include <string>
#include <algorithm>
#include <set>
#include <map>
#include <set>
#include <cstdlib>
#include <cassert>
#include <unordered_map>
#include <unordered_set>
#include <queue>
#include <numeric>
#include <deque>
#include <random>
#include <chrono>
#include <ctime>
#include <climits>
#include <stack>
#include <array>
#include <iomanip>
#include <complex>
#include <bitset>
#include <iostream>
#include <cstring>

using namespace std;
using ll = long long;
using ld = double;

#define n_l '\n'
#define dbg(...) cout << "[" << #__VA_ARGS__ << "]: "; cout << to_string(__VA_ARGS__) << endl
template <typename T, size_t N> int SIZE(const T(&t)[N]) { return N; } template<typename T> int SIZE(const T &t) { return t.size(); } string to_string(const string s, int x1 = 0, int x2 = 1e9) { return '"' + ((x1 < s.size()) ? s.substr(x1, x2 - x1 + 1) : "") + '"'; } string to_string(const char* s) { return to_string((string)s); } string to_string(const bool b) { return (b ? "true" : "false"); } string to_string(const char c) { return string({ c }); } template<size_t N> string to_string(const bitset<N> &b, int x1 = 0, int x2 = 1e9) { string t = ""; for (int __iii__ = min(x1, SIZE(b)), __jjj__ = min(x2, SIZE(b) - 1); __iii__ <= __jjj__; ++__iii__) { t += b[__iii__] + '0'; } return '"' + t + '"'; } template <typename A, typename... C> string to_string(const A(&v), int x1 = 0, int x2 = 1e9, C... coords); int l_v_l_v_l = 0, t_a_b_s = 0; template <typename A, typename B> string to_string(const pair<A, B> &p) { l_v_l_v_l++; string res = "(" + to_string(p.first) + ", " + to_string(p.second) + ")"; l_v_l_v_l--; return res; } template <typename A, typename... C> string to_string(const A(&v), int x1, int x2, C... coords) { int rnk = rank<A>::value; string tab(t_a_b_s, ' '); string res = ""; bool first = true; if (l_v_l_v_l == 0) res += n_l; res += tab + "["; x1 = min(x1, SIZE(v)), x2 = min(x2, SIZE(v)); auto l = begin(v); advance(l, x1); auto r = l; advance(r, (x2 - x1) + (x2 < SIZE(v))); for (auto e = l; e != r; e = next(e)) { if (!first) { res += ", "; } first = false; l_v_l_v_l++; if (e != l) { if (rnk > 1) { res += n_l; t_a_b_s = l_v_l_v_l; }; } else { t_a_b_s = 0; } res += to_string(*e, coords...); l_v_l_v_l--; } res += "]"; if (l_v_l_v_l == 0) res += n_l; return res; } void dbgm() { ; } template<typename Heads, typename... Tails> void dbgm(Heads H, Tails... T) { cout << to_string(H) << " | "; dbgm(T...); }
#define dbgm(...) cout << "[" << #__VA_ARGS__ << "]: "; dbgm(__VA_ARGS__); cout << endl

//#define FAST_ALLOCATOR_MEMORY 2e8

#ifdef FAST_ALLOCATOR_MEMORY // 2e8
int allocator_pos = 0;
char allocator_memory[(int)FAST_ALLOCATOR_MEMORY];
inline void * operator new (size_t n) {
	char *res = allocator_memory + allocator_pos;
	allocator_pos += n;
	assert(allocator_pos <= (int)FAST_ALLOCATOR_MEMORY);
	return (void *)res;
}
inline void operator delete (void *) noexcept { }
//inline void * operator new [] ( size_t ) { assert(0); }
//inline void operator delete [] ( void * ) { assert(0); }
#endif

bool DEBUGGING = 0;

#define all(a) a.begin(), a.end()
#define pii pair<int, int>
#define len(a) (int)a.size()
#define pb push_back
#define eb emplace_back
#define em emplace
#define y0 withindarkness
#define y1 apinklotusbloomed
#define yn carryingapurplesoul
#define j1 togetherformingtheTeam

/*Всё,
пиздуй-бороздуй, и я попиздил, нахуй*/

void useiostream() {
	ios_base::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	cerr.tie(0);
}

void drop(char const *bu) {
	printf("%s", bu);
	exit(0);
}

ll gcd(ll a, ll b) {
	return b == 0 ? a : gcd(b, a % b);
}

ll lcm(ll a, ll b) {
	return a / gcd(a, b)*b;
}

ld const pi = acos(-1.0);
ld const eps = 0.000000001;

template<typename T, typename TT> bool mi(T &a, TT b) { return a > b ? (a = b, true) : false; }
template<typename T, typename TT> bool ma(T &a, TT b) { return a < b ? (a = b, true) : false; }

mt19937 ran(time(0));

int const mod = (int)1e9 + 9;

int bp(int a, int p) {
	int re = 1;
	while (p) {
		if (p & 1)re = (re *1LL* a) % mod;
		p >>= 1;
		a = (a *1LL * a) % mod;
	}
	return re;
}

int inv(int a) {
	return bp(a, mod - 2);
}

int n, m;
int arr[505][505][15];
int cnt[505][15];

int main() {

#ifdef _DEBUG
	DEBUGGING = 1;
	freopen("input.txt", "r", stdin);
	freopen("output.txt", "w", stdout);
#else
	//freopen("points.in", "r", stdin);
	//freopen("points.out", "w", stdout);
#endif

	useiostream();
	cin >> n >> m;
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < m; j++) {
			int a;
			cin >> a;
			for (int k = 0; k < 10; k++) {
				arr[i][j][k] = ((a & (1 << k)) != 0);
				cnt[i][k]+= arr[i][j][k];
			}
		}
	}

	for (int k = 0; k < 10; k++) {
		vector<int> ps(n);
		vector<int> res(n);
		for (int i = 0; i < n; i++)ps[i] = i;
		sort(all(ps), [&](int l, int r) {return cnt[l][k] > cnt[r][k]; });
		int ct = 0;
		int last = -1;
		for (int i = 0; i < n; i++) {
			if (cnt[ps[i]][k] == m) {
				ct++;
				last = i;
			}
		}
		if (ct & 1) {
			cout << "TAK\n";
			for (int i = 0; i <= last; i++) {
				res[ps[i]] = 1;
			}
			for (int i = last + 1; i < n; i++) {
				for (int j = 0; j < m; j++) {
					if (arr[ps[i]][j][k] == 0)res[ps[i]] = j + 1;
				}
			}
			for (int i = 0; i < n; i++) {
				cout << res[i] << " ";
			}
			return 0;
		}
		else {
			for (int i = last + 1; i < n && (ct % 2 )== 0; i++) {
				if (cnt[ps[i]][k]) {
					for (int j = 0; j < m; j++)if (arr[ps[i]][j][k]) {
						ct++;
						
						break;
					}
				}
			}
			if (ct & 1) {
				cout << "TAK\n";
				for (int i = 0; i <= last; i++) {
					res[ps[i]] = 1;
				}
				bool got = 0;
				for (int i = last + 1; i < n; i++) {
					if (cnt[ps[i]][k] && !got) {
						got = 1;
						for (int j = 0; j < m; j++)if (arr[ps[i]][j][k])res[ps[i]] = j + 1;
					}
					else {
						for (int j = 0; j < m; j++)if (arr[ps[i]][j][k] == 0)res[ps[i]] = j + 1;
					}
				}
				for (int i = 0; i < n; i++) {
					cout << res[i] << " ";
				}
				return 0;
			}
		}
	}

	cout << "NIE";
	return 0;
}