{"trustable":true,"prependHtml":"\u003cscript\u003e window.katexOptions \u003d { disable: true }; \u003c/script\u003e\n\u003cscript type\u003d\"text/x-mathjax-config\"\u003e\n MathJax.Hub.Config({\n tex2jax: {\n inlineMath: [[\u0027$$$\u0027,\u0027$$$\u0027], [\u0027$\u0027,\u0027$\u0027]],\n displayMath: [[\u0027$$$$$$\u0027,\u0027$$$$$$\u0027], [\u0027$$\u0027,\u0027$$\u0027]]\n }\n });\n\u003c/script\u003e\n\u003cscript async src\u003d\"https://mathjax.codeforces.org/MathJax.js?config\u003dTeX-AMS-MML_HTMLorMML\" type\u003d\"text/javascript\"\u003e\u003c/script\u003e","sections":[{"title":"","value":{"format":"HTML","content":"\u003cdiv class\u003d\"panel_content\"\u003e给定一个N*N矩阵,每个元素都等于0或1。你可以交换任意两行或任意两列。你能找到一种方法使得所有对角线上的元素都等于1吗?\u003c/div\u003e"}},{"title":"输入","value":{"format":"HTML","content":"输入中包含多个测试用例。每个测试用例的第一行是一个整数N(1 \u003c\u003d N \u003c\u003d 100)。接下来有N行,每行包含N个用空格分隔的数字(0或1),表示N*N的矩阵。"}},{"title":"输出","value":{"format":"HTML","content":"对于每个测试用例,第一行包含交换次数M。然后是M行,格式为“R a b”或“C a b”,表示交换第a行和第b行,或交换第a列和第b列(1 \u003c\u003d a, b \u003c\u003d N)。任何正确答案都将被接受,但M应该大于1000。\u003cbr\u003e\u003cbr\u003e如果无法使所有对角线上的元素都等于1,则输出只包含“-1”的一行。\u003cbr\u003e"}},{"title":"样例","value":{"format":"HTML","content":"\u003ctable class\u003d\u0027vjudge_sample\u0027\u003e\n\u003cthead\u003e\n \u003ctr\u003e\n \u003cth\u003eInput\u003c/th\u003e\n \u003cth\u003eOutput\u003c/th\u003e\n \u003c/tr\u003e\n\u003c/thead\u003e\n\u003ctbody\u003e\n \u003ctr\u003e\n \u003ctd\u003e\u003cpre\u003e2\r\n0 1\r\n1 0\r\n2\r\n1 0\r\n1 0\r\n\u003c/pre\u003e\u003c/td\u003e\n \u003ctd\u003e\u003cpre\u003e1\r\nR 1 2\r\n-1\r\n\u003c/pre\u003e\u003c/td\u003e\n \u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e"}}]}