Click
Here to go back to the homepage.
Nine Knights Solution:
#include <bits/stdc++.h>
using namespace std;
int main(){
// #ifndef TESTING
// freopen("input.txt", "r", stdin);
// freopen("output.txt", "w", stdout);
// #endif
char board[5][5];
for(int i = 0; i < 5; i++){
for(int j = 0; j < 5; j++){
cin >> board[i][j];
}
}
bool valid = true;
int knights = 0;
for(int i = 0; i < 5; i++){
for(int j = 0; j < 5; j++){
if(board[i][j] == 'k'){
knights++;
if((i - 1 >= 0 && j - 2 >= 0 && board[i - 1][j - 2] == 'k') ||
(i - 1 >= 0 && j + 2 < 5 && board[i - 1][j + 2] == 'k') ||
(i + 1 < 5 && j - 2 >= 0 && board[i + 1][j - 2] == 'k') ||
(i + 1 < 5 && j + 2 < 5 && board[i + 1][j + 2] == 'k') ||
(i - 2 >= 0 && j - 1 >= 0 && board[i - 2][j - 1] == 'k') ||
(i + 2 < 5 && j - 1 >= 0 && board[i + 2][j - 1] == 'k') ||
(i - 2 >= 0 && j + 1 < 5 && board[i - 2][j + 1] == 'k') ||
(i + 2 < 5 && j + 1 < 5 && board[i + 2][j + 1] == 'k')
){
valid = false;
}
}
}
}
if(valid && knights == 9){
cout << "valid" << endl;
} else {
cout << "invalid" << endl;
}
return 0;
}