Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - KINGARZA

#1
Buenas a todos!
Pues como voy empezando en el mundo del desarrollo android me he propuesto desarrollar un TicTacToe, el problema radica en que no se como hacer que las tres celdas ocupen el mismo espacio proporcional.

Leí por internet que empleando android:layout_weight="1" se solucionaba, pero no...
Gracias por leerlo!

El código que empleo
Código (xml) [Seleccionar]

<TableRow
        android:layout_height="wrap_content"
        android:layout_width="fill_parent"
        >

        <TextView
            android:id="@+id/uno"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1"

            android:text="X"
            android:textSize="35sp"
            android:textColor="#000000"

            android:padding="25dp"
            android:gravity="center"
            android:background="#F78181"
            />

        <TextView
            android:id="@+id/dos"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1"

            android:text="X"
            android:textSize="35sp"
            android:textColor="#000000"

            android:padding="25dp"
            android:gravity="center"
            android:background="#FF00FF"
            />
        <TextView
            android:id="@+id/tres"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1"

            android:text="X"
            android:textSize="35sp"
            android:textColor="#000000"

            android:padding="25dp"
            android:gravity="center"
            android:background="#F78181"
            />
</TableRow>
#2
Buenas a todos!!

Hace poco tenia la siguiente cuestión:
https://foro.elhacker.net/dudas_generales/automatizar_tareas_en_la_web-t479005.0.html

Gracias a su apoyo he tenido un gran avance pero tengo una duda que no he encontrado como resolverla...

Antes que nada he hecho un formulario, el cual consta de 4 campos:
*ID
*Fecha de nacimiento

Cuando el usuario ingresa la información correcta (Id = A5 Dia = 1 Mes = 2 año = 3) en un nueva pagina se le da el mensaje de bienvenida, de lo contrario se abre una nueva pagina con el mensaje sigue intentando.

El problema es que supongamos el usuario olvida su contraseña y no hay otra manera de obtenerla mas que usando la bruta, el sabe que el ID solo consta de una letra mayúscula del alfabeto ingles y un numero, es decir el total de combinaciones posibles seria:
26 * 10 * 5 * 5 * 5 = 32500

Notar que la ID en este caso consta de una letra mayúscula del alfabeto ingles y un numero, los demás datos (día, mes, año) están limitados a 5 valores.

Intentar manualmente esas 32,500 combinaciones seria prácticamente imposible...

Encontré la manera de acceder desde el DOM a los campos del formulario:

document.getElementsByTagName("form")[0].ID.value
document.getElementsByTagName("form")[0].dia.value
document.getElementsByTagName("form")[0].mes.value
document.getElementsByTagName("form")[0].año.value
document.getElementById("Enviar").click()


Mi pregunta es la siguiente:

Como puedo intentar todas las posibles combinaciones hasta que ingrese los datos correctos, es decir, hasta que el formulario me envié a la pagina de bienvenido?

Mi idea es la siguiente (pero no se como llevarla acabo):

A cada campo del formulario le asigno el valor de una posible combinación, por ejemplo:

document.getElementsByTagName("form")[0].ID.value = "A1"
document.getElementsByTagName("form")[0].dia.value = "1"
document.getElementsByTagName("form")[0].mes.value = "1"
document.getElementsByTagName("form")[0].año.value = "1"
document.getElementById("Enviar").click()

Y después encuentro la manera de pegar ese código en la consola (cuando damos inspeccionar pagina) y si me da el mensaje de bienvenida pues excelente, allí paro, sino seguir intentado las demás combinaciones...

Dejo el código del formulario en HTML Y javascript y el generador de combinaciones en lenguaje C++

Código (javascript) [Seleccionar]

<html>

<head>
<title>"Example 1"</title>
</head>

<body>

<h1>Formulario</h1>
<br/>

<form target = "_blank" action = ""  method = "POST">

<input type = "text" id = "ID", name = "ID" placeholder = "Introduce tu ID aqui">
<select id = "dia" name = "dia">
<option value = "0">Selecciona el Dia</option>
<option value = "1">01</option>
<option value = "2">02</option>
<option value = "3">03</option>
<option value = "4">04</option>
<option value = "5">05</option>
</select>
<select id = "mes" name = "mes">
<option value = "0">Selecciona el Mes</option>
<option value = "1">01 Enero</option>
<option value = "2">02 Febrero</option>
<option value = "3">03 Marzo</option>
<option value = "4">04 Abril</option>
<option value = "5">05 Mayo</option>
</select>
<select id = "año" name = "año">
<option value = "0">Selecciona el año</option>
<option value = "1">2001</option>
<option value = "2">2002</option>
<option value = "3">2003</option>
<option value = "4">2004</option>
<option value = "5">2005</option>
</select>
<br/>
<br/>
<input type = "submit" id = "Enviar" name = "Enviar" value = "Enviar" onclick = "Evaluar()">

</form>

<script>
function Evaluar(){
var ID = document.getElementById("ID").value,
Dia = document.getElementById("dia").value,
Mes = document.getElementById("mes").value,
año = document.getElementById("año").value;
if(ID === "A5" && Dia === "1" && Mes === "2" && año === "3")
document.write("Bienvenido");
else
document.write("Sigue intentado");
}
</script>
</body>
</html>


Código (cpp) [Seleccionar]

#include<bits/stdc++.h>
using namespace std;

vector<string>Combinacion;

void genera_combinaciones(){
   for(char i = 'A'; i <= 'Z'; i++)
       for(char j = '0'; j <= '9'; j++){
           string cad = "";
           cad.push_back(i);
           cad.push_back(j);
           Combinacion.push_back(cad);
       }
}

int main(){
   ofstream File("Combinaciones.txt");
   int t = 0;
   genera_combinaciones();
   for(int i = 0; i < Combinacion.size(); i++)
       for(int dia = 1; dia <= 5; dia++)
           for(int mes = 1; mes <= 5; mes++)
               for(int año = 1; año <= 5; año++)
                   File<<Combinacion[i]<<" "<<dia<<" "<<mes<<" "<<año<<"\n", t++;
   File<<"Total de combinaciones: "<<t;
   File.close();
}

Gracias por tu atencion :rolleyes:
#3
Muchas gracias "engel lex"!!
#4
Gracias por responder  ;-), la verdad no entiendo mucho de lo que me dices (dado que nunca he programado en js y html, y en general nunca he estudiado este campo de la informática) y ese termino de ajax tampoco lo había escuchado antes  :-\.
Que me recomiendas aprender entonces? (Si tienes algún material que me ayude a profundizar en esto seria muy gratificante)
#5
Buenas a todos!
Desde hacer tiempo que en mi colegio (cursando la preparatoria) suben las calificaciones en una plataforma en donde cada estudiante se le asigna una clave, ya con esta ingresas tu fecha de nacimiento y puedes entrar a tu cuenta para ver tu perfil.

Le pedí a varios amigos su clave y me doy cuenta que de 9 caracteres  los primeros 6 son los mismos, y los tres últimos (que son solo números) es lo que cambia.

Afortunadamente tengo fuertes conocimientos en algoritmos (y solo conozco el lenguaje C/C++), puedo obtener todas las combinaciones posibles, pero mi problema es:

Como lleno cada campo de la plataforma automáticamente?

Es decir, en vez de yo usuario copiar y pegar cada combinación (poner la clave, y fecha de nacimiento) en su campo correspondiente me gustaría hacer esto de manera automática

Si pudieran indicarme que aprender para hacer esto (realizar tareas iterativas automáticamente) o compartirme algún pdf relacionado estaría genial!
Cualquier información sirve, gracias por su atención!
#6
Mira lo que pasa es que estoy intentado resolver un problema tipo laberinto, en el cual quiero conocer en cada estado:
*la distancia recorrida,
*mi posición
*la posición del otro objeto
y como sabrás en este tipo de problema piden el camino mas corto, entonces lo que hago es poner así la estructura:
d, x, y, x2, y2
donde d =  distancia recorrida hasta ese momento, y como el set ordena de menor a mayor cumple la función que deseo.
Y en cuanto eso de que no permiten repeticiones no importa, pues tengo una matriz de casillas visitadas.

Mi pregunta inicial era como acceder a todos los elementos cuando uso 4 Pairs anidados?
(En base a este codigo que habia mostrado
Código (cpp) [Seleccionar]
#define Estado pair<int, pair<int, pair<int, pair<int, int> > > >
set<Estado>Cola;

)
Por cierto, buen Blog!! :-*
#7
Gracias por responder :laugh:, uso la estructura set, para evitar implementar una cola de prioridad con MIN. y pues como bien comentas los ordena de menor a mayor, ademas existe la priority_queue de la stl, pero este set me va mejor en rendimiento.
#8
Quiza no responda tu pregunta pero te daré una recomendación, ¿Porque no generas una cédula aleatoria?

Motivos:

*Evitas que el usuario se desgaste pensando en ello
*Te evitaras menos lineas de codigo

Una forma de hacerlo es usando la funcion rand(), o bien en base a los nombres (ya que son unicos) puedes concatenar, por ejemplo:
"Enrique Peña Nieto" -> EnPeNi
#9
Hola a todos!
Quiero hacer una cola que guarde cinco valores y para ello estoy usando la estructura PAIR de c++, el problema esta en como acceder a estos elementos.

El codigo de abajo muestra como defino el estado y la cola de este tipo
Código (cpp) [Seleccionar]

#define Estado pair<int, pair<int, pair<int, pair<int, int> > > >
set<Estado>Cola;


Por ejemplo, se que para acceder al primer elemento es:
Código (cpp) [Seleccionar]

int a = (*Cola.begin()).first;


Para el segundo elemento es:
Código (cpp) [Seleccionar]

int a = (*Cola.begin()).second.first;


Podrias ayudarme por favor?
#10
Hola que tal, ando intentando un problema de un juez en linea https://omegaup.com/arena/problem/decepcion#problems

Dado un entero n, se forma una fila de n torres con alturas desde 1 hasta n centímetros, ninguna altura aparece más de una vez. Se quieren conocer todas las permutaciones de esta fila tal que viendo la fila de frente solo se vean F torres diferentes y vista por detrás solo se vean B torres. Se dice que podemos ver una torre con altura H si no hay otra torre delante de ella (con respecto a nuestra visión) con altura mayor a H.

Entrada

Tres enteros separados por espacios: n, F y B.

Salida

Un entero que representa el número de permutaciones que cumplen con las condiciones establecidas.

Ejemplo

4 2 3
3
Las tres permutaciones posibles son:
Frente → 2 4 3 1
Frente → 1 4 3 2
Frente → 3 4 2 1

Límites

1≤n,F,B≤13


En el cual tengo una respuesta que me da 55 puntos, me da tiempo limite excedido
Podrias darme una ayuda?
Por ejemplo alguna poda o mucho mejor alguna pagina donde expliquen temas de este tipo
, etc..., todo es bueno.
Bueno y pues lo que hago es literal hacer lo que pide el problema, no tengo ninguna poda
(en un principio pense que el numero mayor seria un numero fijo, si viste en el ejemplo viene:

4 2 3
3
Las tres permutaciones posibles son:
Frente → 2 4 3 1
Frente → 1 4 3 2
Frente → 3 4 2 1

pero si pongo este otro caso ya no es factible

5 3 2

unas permutaciones posibles son:

12534

13254

)
Código (cpp) [Seleccionar]

#include <bits/stdc++.h>
using namespace std;

bool visitado[15];
string cad[] = {"1", "2", "3", "4", "5", "6", "7", "8", "9", ":",";", "<", "="};//si checas el codigo ascii despues del 9 sigue el ":" y luego el ";", etc..., es decir, que poner ":" es como poner 10, etc.

int n, x, y, C;//C = contador = permutaciones validas

bool esValido_izq(string tmp){
   int a = 1, mayor = tmp[0];
   for(int i = 1; i < n; i++)
       if(tmp[i] > mayor)
           mayor = tmp[i], a++;
   return (a == x);
}

bool esValido_der(string tmp){
   reverse(tmp.begin(), tmp.end());
   int a = 1, mayor = tmp[0];
   for(int i = 1; i < n; i++)
       if(tmp[i] > mayor)
           mayor = tmp[i], a++;
   return (a == y);
}

void permutar(string tmp = ""){
if(tmp.size() == n){
       if(esValido_izq(tmp) && esValido_der(tmp)){
           C++;
           //cout<<"\n"<<tmp<<"\n"; //descomentar para ver las permutaciones validas
       }
       return;
}
for(int i = 0; i < n; i++)
if(!visitado[i]){
visitado[i] = true;
permutar(tmp + cad[i]);
visitado[i] = false;
}
}

int main(){
   cin>>n>>x>>y;
   permutar();
   cout<<C;
}