Comentário OBOI 2024 Primeira Fase – Problema “Damas”

por

Comentário por Henrique Vianna

Conhecimento prévio necessário:

Para achar a resposta para uma dada dama i, basta checarmos para cada outra dama j se ela se encontra na mesma linha, coluna ou diagonal de i. Para tanto, deve-se checar os seguintes casos:

  • Mesma linha: verdade se l_i == l_j.
  • Mesma coluna: verdade se c_i == c_j.
  • Mesma diagonal: verdade se |l_i - l_j|==|c_i-c_j|.

Se  qualquer uma dessas condições for verdadeira, deve-se somar 1 à resposta de i. Então, basta fazer dois loops, um para cada dama i e outro passando por cada dama j\neq i. Segue o código:


#include <bits/stdc++.h>
using namespace std;
const int MAX = 75;
int n, x[MAX], y[MAX];
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cin >> n;
for(int i = 1; i <= n; i++)
cin >> x[i] >> y[i];
for(int i = 1; i <= n; i++)
{
int ataques = 0;
for(int j = 1; j <= n; j++)
{
if(i == j) continue;
int dx = x[j] – x[i], dy = y[j] – y[i];
if(dx == 0 || dy == 0 || abs(dx) == abs(dy))
ataques++;
}
cout << ataques << '\n';
}
}

view raw

Damas.cpp

hosted with ❤ by GitHub