-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path1827.c
73 lines (55 loc) · 1.52 KB
/
1827.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include <stdio.h>
/*
* -----------------------------------
* | Pedro Daniel Jardim |
* | UFV |
* | 28/02/2020 |
* ----------------------------------
*
*/
void matrix(unsigned short);
int main ()
{
unsigned short tamanho;
while (scanf("%hd", &tamanho) != EOF)
{
matrix(tamanho);
}
}
void matrix(unsigned short tamanho)
{
int m[tamanho][tamanho];
unsigned short linha, coluna;
// Preenche a matriz com 2 na diagonal principal;
// 3 na diagonal secundária;
// e 0 nas demais posições;
for (linha = 0; linha < tamanho; linha++)
for (coluna = 0; coluna < tamanho; coluna++)
{
if (linha == coluna)
m[linha][coluna] = 2;
else if (linha == tamanho - coluna - 1)
m[linha][coluna] = 3;
else
m[linha][coluna] = 0;
}
// Dica dada pela questão;
unsigned short inicio = tamanho/3;
// O problema é achar a condição de parada, ou seja, o fim;
// O final seria o tamanho menos o início, para sempre sobrar a
// mesma quantidade de colunas em ambos os lados;
unsigned short fim = tamanho - inicio;
for (linha = inicio; linha < fim; linha++)
for (coluna = inicio; coluna < fim; coluna++)
m[linha][coluna] = 1;
// O tamanho dividido por 2 sempre nos dá o elemento central;
m[tamanho/2][tamanho/2] = 4;
// Apenas imprime a matriz resultante;
for (linha = 0; linha < tamanho; linha++)
{
for (coluna = 0; coluna < tamanho; coluna++)
printf("%d", m[linha][coluna]);
printf("\n");
}
printf("\n");
}