Lines Matching refs:Col

13   constexpr Board addQueen(int Row, int Col) const {  in addQueen()
14 return Board(State | ((uint64_t)Row << (Col * 4))); in addQueen()
16 constexpr int getQueenRow(int Col) const { in getQueenRow()
17 return (State >> (Col * 4)) & 0xf; in getQueenRow()
19 constexpr bool ok(int Row, int Col) const { in ok()
20 return okRecurse(Row, Col, 0); in ok()
22 constexpr bool okRecurse(int Row, int Col, int CheckCol) const { in okRecurse()
23 return Col == CheckCol ? true : in okRecurse()
25 getQueenRow(CheckCol) == Row + (Col - CheckCol) ? false : in okRecurse()
26 getQueenRow(CheckCol) == Row + (CheckCol - Col) ? false : in okRecurse()
27 okRecurse(Row, Col, CheckCol + 1); in okRecurse()
29 constexpr bool at(int Row, int Col) const { in at()
30 return getQueenRow(Col) == Row; in at()
35 constexpr Board buildBoardRecurse(int N, int Col, const Board &B);
36 constexpr Board buildBoardScan(int N, int Col, int Row, const Board &B);
38 int N, int Col, int Row, const Board &B) { in tryBoard() argument
39 return Try.Failed ? buildBoardScan(N, Col, Row, B) : Try; in tryBoard()
41 constexpr Board buildBoardScan(int N, int Col, int Row, const Board &B) { in buildBoardScan() argument
43 B.ok(Row, Col) ? in buildBoardScan()
44 tryBoard(buildBoardRecurse(N, Col + 1, B.addQueen(Row, Col)), in buildBoardScan()
45 N, Col, Row+1, B) : in buildBoardScan()
46 buildBoardScan(N, Col, Row + 1, B); in buildBoardScan()
48 constexpr Board buildBoardRecurse(int N, int Col, const Board &B) { in buildBoardRecurse() argument
49 return Col == N ? B : buildBoardScan(N, Col, 0, B); in buildBoardRecurse()
57 constexpr bool Board::check(const char *p, int Row, int Col) const { in check()
60 *p == 'o' ? at(Row, Col) && check(p+1, Row, Col+1) : in check()
61 *p == '-' ? !at(Row, Col) && check(p+1, Row, Col+1) : in check()