-
Notifications
You must be signed in to change notification settings - Fork 0
/
egg28.java
142 lines (138 loc) · 6.05 KB
/
egg28.java
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package luco.java_egg_1;
/**
*
* @author Usuario
*/
public class egg28 {
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
int contador = 0;
int[][] matrizGrande = new int[10][10]; //matriz de 10 por 10
// int[] fila1 = {1, 26, 36, 47, 5, 6, 72, 81, 95, 10};
// int[] fila2 = {11, 12, 13, 21, 41, 22, 67, 20, 10, 61};
// int[] fila3 = {56, 78, 87, 90, 9, 90, 17, 12, 87, 67};
// int[] fila4 = {41, 87, 24, 56, 97, 74, 87, 42, 64, 35};
// int[] fila5 = {32, 76, 79, 1, 36, 5, 67, 96, 12, 11};
// int[] fila6 = {99, 13, 54, 88, 89, 90, 75, 12, 41, 76};
// int[] fila7 = {67, 78, 87, 45, 14, 22, 26, 42, 56, 78};
// int[] fila8 = {98, 45, 34, 23, 32, 56, 74, 16, 19, 18};
// int[] fila9 = {24, 67, 97, 46, 87, 13, 67, 89, 93, 24};
// int[] fila10 = {21, 68, 78, 98, 90, 67, 12, 41, 65, 12};
//Vector para rellenar matriz grande
int[] vectorGrande = { //numeros permitidos w
1, 26, 36, 47, 5, 6, 72, 81, 95, 10,
11, 12, 13, 21, 41, 22, 67, 20, 10, 61,
56, 78, 87, 90, 9, 90, 17, 12, 87, 67,
41, 87, 24, 56, 97, 74, 87, 42, 64, 35,
32, 76, 79, 1, 36, 5, 67, 96, 12, 11,
99, 13, 54, 88, 89, 90, 75, 12, 41, 76,
67, 78, 87, 45, 14, 22, 26, 42, 56, 78,
98, 45, 34, 23, 32, 56, 74, 16, 19, 18,
24, 67, 97, 46, 87, 13, 67, 89, 93, 24,
21, 68, 78, 98, 90, 67, 12, 41, 65, 12
};
//Rellenar matriz grande
for(int i = 0; i < 10; i++) { //lit lo dice arriba maestro. rellenar we
for(int j = 0; j < 10; j++) {
matrizGrande[i][j] = vectorGrande[contador];
contador += 1;
}
}
// Imprimir matriz grande
System.out.println("Matriz Grande");
for(int i = 0; i < 10; i++) {
for(int j = 0; j < 10; j++) {
System.out.print(matrizGrande[i][j] + " ");
}
System.out.println("");
}
// Vector para rellenar matriz chica
int[] vectorChico = {36, 5, 67, 89, 90, 75, 14, 22, 26}; //matriz chiquita wi
// Rellenar matriz chica
int[][] matrizChica = new int[3][3];
contador = 0;
for(int i = 0; i < 3; i++) {
for(int j = 0; j < 3; j++) {
matrizChica[i][j] = vectorChico[contador];
contador += 1;
}
}
// Mostrar matriz chica
System.out.println("Matriz Chica");
for(int i = 0; i < 3; i++) {
for(int j = 0; j < 3; j++) {
System.out.print(matrizChica[i][j] + " ");
}
System.out.println("");
}
// Contar coordenadas para las cuales coincide el primer valor de la matriz chica
contador = 0;
for(int i = 0; i < 10; i++) {
for(int j = 0; j < 10; j++) {
if(matrizGrande[i][j] == matrizChica[0][0]) {
contador += 1;
}
}
}//aca esta la parte mas dura we
// Vectores de posicion en los que las coordenadas son iguales al primer numero de la matriz chica
int[] absc = new int[contador];
int[] ord = new int[contador];
// Obtengo los vectores de posicion
contador = 0;
for(int i = 0; i < 10; i++) {
for(int j = 0; j < 10; j++) {
if(matrizGrande[i][j] == matrizChica[0][0]) {
System.out.println("Coordenada " + contador );
System.out.println(i + "," + j);
absc[contador] = i;
ord[contador] = j;
contador += 1;
}
}
}
// Uso x e y para recorrer la matriz chica mientras que j y k recorren la matriz grande; i es para iterar las distintas coordenadas validas para las cuales
// el primer valor de la matriz chica coincide dentro de la grande
int iguales;
int x = 0;
int y = 0;
for(int i = 0; i < contador; i++) {
iguales = 0;
// System.out.println(absc[i] + ", " + ord[i]);
// System.out.println(absc[i] + 3 + ", " + (int) (ord[i] + 3));
System.out.println("Para la coordenada: " + i);
x = 0;
// Posicion desde la coordenada hasta la misma coordenada corrida 3 lugares (3 x 3) para verificar la matriz chica dentro de la grande
for(int j = absc[i]; j < absc[i] + 3; j++) {
y = 0;
for(int k = ord[i]; k < ord[i] + 3; k++) {
// System.out.println("K:" + k);
// Cada vez que los valores sean iguales se suma un contador para luego verificar si es o no una matriz P contenida dentro de la matriz M
if(matrizGrande[j][k] == matrizChica[x][y]) {
iguales += 1;
System.out.println("Son iguales en: " + x + ", " + y);
}
// System.out.println("Y: " + y);
y += 1;
}
// System.out.println("J: " + j);
// System.out.println("X: " + x);
x += 1;
// System.out.println("Iguales: " + iguales);
}
// Se verifica que la cantidad de valores iguales sea igual que el rango de la matriz chica, es decir, 3 * 3 = 9
if(iguales == 9) {
System.out.println("La coordenada valida es: " + absc[i] + ", " + ord[i]);
} else {
System.out.println("No existe una matriz P dentro de la matriz M");
}
}
}
}
//ni idea we anda bien jeeeeeeeee