elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: ¿Eres nuevo? ¿Tienes dudas acerca del funcionamiento de la comunidad? Lee las Reglas Generales


  Mostrar Mensajes
Páginas: 1 ... 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 [336] 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 ... 431
3351  Programación / Programación Visual Basic / Re: SQL SUM() AS .. FROM ... WHERE... que no funciona en: 31 Diciembre 2017, 02:43 am
El código resulta un poco espagueti, por la vaguedad en los nombres, pero bueno...

Según tú...: ...where inversor = 'inversorx'
Pero ausmo que inversorX es una variable no una cadena de texto literal...

es decir si fuera una cadena de texto literal, hubieras puesto:
 
Código
  1.  ...where inversor = "'inversorx'"
 
Pero si es una variable debe poner:
 
Código
  1.  
  2. ...where inversor = inversorx
Y si el contenido de  inversorx, debe estrar entre comillas simples deberías poner:
Código
  1. inversorX = "'" & inversorX & "'"  ' en alguna parte pondrías esto
  2.  ...
  3. ...where inversor = inversorX   ' par al final hacer esto
  4.  

...en fin apunta el ratón en la palabra inversorx, y con el otro botón del ratón da click, y cuando emerja el menú flotante, selecciona: 'definición' y te llevará a la declaración de la variale, si lo es... (aunque es algo que tu debieras saber (los demás no, porque no vemos declaraciones de variables por ningún lado en tu código escueto).

Corrige las comillas según lo que sea (uno de los 3 casos antedichos).


p.d.: también si encerraras tu código entre etiquetas GeSHi, el coloreado del texto, lo haría más legible...
3352  Programación / Programación C/C++ / Re: Maquina Inteligente Hundir la flota (Battleship) código C en: 31 Diciembre 2017, 02:13 am
Simplemente debes tener una estructura (sencilla) donde mantener dicha info, para seguir indagando.


Una imagen para que hagas una idea de como queda y luego la estructura, detrás las explicaciones

Cerco:

.|0 1 2 3 4 5 6
A|X X X 4 X X X
B|X X X 4 X X X
C|X X X 4 X X X
D|2 2 2 @ 1 1 1
E|X X X 3 X X X
F|X X X 3 X X X
G|X X X 3 X X X



Finalmente tendrías una estructura para mantener junto los datos tal que así:

Código:
Estructura DatosDisparo     
     byte Tocado                     // indica cuando se toca por vez primera una nave, y luego con cada nuevo 'tocado' aumenta en uno. asi este valor hasta hundirlo.
     byte Orientacion              // indica a qué lado estamos disparando del cerco.
     //byte cX                        // cordenada 'x' del primer tocado en la nave.
     //byte cY                        // cordenada 'y' del primer tocado en la nave.
     //arrayBytes Cerco(7,7)  // Array imaginario, operamos sobre un área de 7x7 (dado un tamaño de nave de 4 casillas)
Fin estructura

DatosDisparo dDisparo     // instancia de la estructura.

La arroba, representa tu primer disparo con acierto. Tocado se pone a 1, Luego siempre sigues la dirección del reloj, empiezas por donde quieras, yo he puesto 1 al este... si aciertas de nuevo sumas 1 a tocado y se avanza en la orientacion y sentido que lleva. Así si es 1, sigues en 1... pero si falla, continúa en la misma dirección pero en el otro sentido, y el valor de orientación se actualiza como toca...
El orden de 1,2,3 y 4, obedece a facilitar el código... otras maneras son posibles, pr supuesto.

La estrategia es que si el disparo ha tocado un buque (valor 2 en tu caso), por primera vez, se consdiera una zona centrada en dicha posición, del mapa de disparos,  centrnado el disparo en dicho array, es decir Cerco(3,3) = 2 // tocado
Y estableces un valor buleano Tocado=1, ahora la posición donde disparar la siguiente vez, va condicionado...

Voy mejor con pseudocódigo, sino con tantos condicionantes es fácil perderse...
Código:
buleano = Funcion SiguienteDisparo(byte resultado, byte x, byte y)  //tu llama la función como te dé la gana... o atendiendo a como te reclamen.   
    Si (resultado = 2)   // Tocado
        Si (dDisparo.Tocado > 0)
            Si (dDisparo.Tocado < 4)  
                dDisparo.Tocado += 1              // Otra casilla tocada de la nave (o de una nave contigua)
          
                Si (dDisparo.Orientacion = 1)    // avanzamos a derecha
                    x += 1
                OSi (dDisparo.Orientacion = 2)   // avanzamos hacia izquierda                
                    x -= 1                  
                OSi (dDisparo.Orientacion = 3)   // avanzamos hacia abajo                    
                    y += 1                              
                OSi (dDisparo.Orientacion = 4)   // avanzamos hacia arriba
                    y -= 1
                Fin si              
            Si no    
                dDisparo.Tocado = 0      
                Devolver FALSE          
                // NOTA2:  Si se ha tocado tantas veces como casillas tiene la nave mayor, cabe decir que hay un buque contiguo a éste (o más)...  
                // no se ha hundido, porque sino, se hubiera recibido un resultado 3.
                // Es decir: al menos dos buques tienen casillas en este área y están tocándose
                // Luego la suma de 'dDisparo.tocado' ha tocado casillas de al menos dos naves,...
                // Resolver este caso, lo dejo a tu esfuerzo y consideración...
            Fin si
        Sino  // aquí hay un buque (lo acabamos de descubrir)... insistiremos hasta hundirlo.
            // Reset valores de la estructura.
            dDisparo.Tocado = 1            
            dDisparo.Orientacion = 1
            //dDisparo.cX = x
            //dDisparo.cY = y
            //CopiarParteDelMapaACerco
            
            x += 1   // orientación: 1, avanzamos a derecha, 'y' no cambia.              
        Fin si      
        Devolver TRUE
    Osi (Resultado = 3)                // Hundido, se supone ya restada una nave.        
        dDisparo.Tocado = 0          // si esta nave está hundida, retiramos la marca para seguir buscando alrededor...
        Devolver FALSE
    Sino
        Si (dDisparo.Tocado > 0)              // un disparo previo acertó,                         
            Si (dDisparo.Orientacion < 4)      // si no se han agotado todas las posibilidades.
                dDisparo.Orientacion += 1      // cambiamos de orientación.
                Si (dDisparo.Orientacion = 2)  // ---> cambia de sentido en horizontal...  hacia izquierda                
                    x -= (dDisparo.Tocado + 1)  // 'y' no cambia                  
                OSi (dDisparo.Orientacion = 3) // ---> cambia a vertical abajo
                    x -= dDisparo.Tocado          // vuelve a la cordenada central (de Cerco) en el eje 'x'
                    y +=1                                // y baja una fila
                OSi (dDisparo.Orientacion = 4) // ---> cambia de sentido en vertical... hacia arriba...
                    y -= (dDisparo.Tocado + 1)  // 'x' no cambia.
                Fin si
                Devolver TRUE
            Sino                                                                              
                dDisparo.Tocado = 0      
                Devolver FALSE
                // NOTA2:  Agotada todas las orientaciones cabe decir que hay un buque contiguo a éste...  
                // no se ha hundido, porque sino, se hubiera recibido un resultado 3.
                // Es decir: al menos dos buques tienen casillas en este área y están tocándose
                // Luego la suma de 'dDisparo.tocado' ha tocado casillas de al menos dos naves,...
                // Resolver este caso, lo dejo a tu esfuerzo y consideración...
            Fin si
        Sino        
            Devolver FALSE
        Fin si
    Fin si
Fin funcion

Observa que en realidad el array 'cerco', no lo usamos para nada, ni copiamos ni escribimos, ni leemos de él, es una idealización para saber que estamos haciendo y 'no perder el norte'...
Los parámetros 'x' e 'y' son de entrada y salida...
La función devuelve un buleano, para indicar si el próximo disparo debe dirigirse el disparo a los valores x,y devueltos si la función devuelve TRUE, si devuelve false, se debe elegir otra posición... pero devlviendo TRUE, 'x' e 'y', contiene la dirección donde disparar para cercar al buque tocado hasta hundirlo.

- Una vez que se ha tocado, un barco, sigue la estrategia de recorrer en la misma orientación hasta el fallo, en cuyo caso se recorre en el sentido opuesto, acabado el otro sentido, cambia la orientación a vertical y finalmente invierte el sentido de este... ese es el orden de recorrido.

- Nota que caben posibilidades de que haya 2 o más naves que estén contiguas (paralelas), por lo que puede darse falso positivo (tocar dos naves distintas y no dos casillas de la misma nave (incluso 3, 4 naves...), con dos disparos seguidos). He dejado un comentario de //NOTA1 y //NOTA2, donde esto sucede... y aún puede darse un caso de NOTA3...

// NOTA2: al caso dDisparo.Tocado contiene el valor de cuantas naves han sido tocadas y la orientación actual descubre que están en una orientación atravesada.
//NOTA1: También cabe la posibilidad de una nave pongamos vertical (que tocamos con 'dDisparo.Tocado = 1, el centro del 'Cerco'), incluso alguna más también en vertical y luego otra en horizontal a continuación de áquella última tocada, luego llegamos a 4 tocados, pero no hay ninguna nave hundida (hubiéramos recibido un valor de resultado = 3)... luego hay que continuar la dirección más allá de las medidas de 'Cerco', para hundirlo y tras hundirlo regresar sus casillas hacia atrás, y continuar en otra dirección...
Ambos casos, los dejo en el limbo, a tu esfuerzo... es más de lo mismo, puede resolverse descontando los Tocados de la nave hundida y cambiar en la otra dirección vertical desde la posición previa (descontada en dicho eje de la nave hundida) //NOTA3: Todavía existe el caso de que dos naves estén colocadas 'a testa' una de otra, también dejo a tu esfuerzo incluso donde va este caso dentro del árbol de decisiones....

Si quieres evitar esos casos molestos, basta que añadas una regla al juego: dos naves no pueden posicionarse  tocándose, siempre debe haber al menos un casilla de espacio entre ellas (con la excusa de que eso impediría el movimiento en un caso real  :laugh: :laugh: :silbar: ). Esto elimina todas esa complicaciones...

Cerco:

.|0 1 2 3 4 5 6
A|X X X 4 X X X
B|X X X 4 X X X
C|X X X 4 X X X
D|2 2 2 @ 1 1 1
E|X X X 3 X X X
F|X X X 3 X X X
G|X X X 3 X X X


Nota que habiendo tocado una casilla y considerando a dicha casilla como el centro de un cerco, basta tocar otras 3, para hundir el barco más grande que haya (supuesto el caso de naves de tamaño 4  como máximo), sin embargo, el cerco aunque sea imaginario de 4 casillas en una dimensión en realidad queda determinado por el valor de Tocado... es decir mientras se toque en una dirección se avanza en ella, así podría a llegar a 5, 6, 10... con lo que en realidad no importa el tamaño de las naves. Pero es preciso, hacer siempre una idealización razonada y cuando procede un dibujo...
Para hacer el pseudocódigo independiente del tamaño de las naves habría que tener una variable donde está línea, para el valor 4, con el valor propio de casillas que tenga la nave de mayor tamaño.
Si (dDisparo.Tocado < 4)

Como el pseudocódigo está escrito al aire (sobre la marcha), es posible que se haya escapado algún gazapo...

-----------------------
Todo lo previo, respecto de tu interés, y ahora respecto de otras observaciones que pareces obviar...
- El valor de: "casilla repetida = 0", es absurdo... es obligado llevar dos mapas (por flota), aunque en realidad el segundo mapa de una flota, es el primero de la otra, luego pueden compartirse parcialmente.
Me explico: ¿quién en su sano juicio tira dos 'bombas' al mismo sitio, si ya fue agua, o tocado???. Y se sabe que fue agua o tocado, porque... en efecto llevas un mapa de donde has tirado previamente, no llevar un mapa es carecer de memoria, luego una IA, no tiene sentido donde no hay ni persistencia de la memoria. La IA es precisamente operar en consideración  de la memoria, de la 'experiencia', mediante la retroalimentación... si no hay memoria, no hay nada que retroalimentar... por eso mantener una estructura de lo que ha sucedido previamente es la IA mínima que se puede prestar...

Así los dos mapas son: Donde yo tiro a la flota enemiga y 2º, donde el enemigo me tira a mi.  es inverso para el caso del enemigo, excepto en que en el mapa propio, están todas las naves y 'el enemigo solo ve', lo que ha tocado o hundido, es decir... si tenemos un valor de nave intacta en el mapa, para el enemigo, se le reprseenta como agua... y si no, toca mantener dos mapas independientes por cada flota.

Es abusrdo hablar de IA, si luego uno va a volver a tirar a casillas a las que ya ha tirado. Hay un caso donde esto es posible, y es en una versión más compleja del juego, donde en cada turno, el que tira mueve una de sus naves (la que quiera) una casilla en uno de los dos sentidos de la orientación que tiene, por lo que en efecto, podrá dispararse a casillas ya disparadas, porque las flotas 'se mueven', pero es una regla que hace el juego mucho más complejo...
---------------

Siento todo el párrafo del mensaje anterior, que al parecer te resulta innecesario,  porque al hacer preguntas, los usuarios a menudo os dejais en el tintero detalles importantes... como "ya tengo listo todo lo demás, me falta solo esto". ...pero bueno, a alguien podrá servirle.
3353  Programación / Programación C/C++ / Re: Maquina Inteligente Hundir la flota (Battleship) código C en: 29 Diciembre 2017, 20:23 pm
Al margen de como muestres por pantalla el mapa, es acertado que en tu array mantengas lo más coherente los datos referentes al estado del mapa.

No sé si te piden-puedes crear clases o si va todo en 'spaguetticode'... yo creraría una clase llamada mapa, que al inicio, al crearse recibe como parámetros el tamaño del mapa, y un array indicando cuantos buques tendrá y de qué tamaño... pero al caso puedes dejar las funciones fuera si no usas clases, duplicando datos para cada jugador...


Las ideas:
- Un array Mapa, contiene el estado del mapa, incialmente sus valoren valen 0, es decir todo agua, las casillas 'tocadas se marcan con valor 255, cualquier otro valor corresponde a la nave x.
- Un array de Naves, tiene tantos elementos como naves se alojarán en el mapa, y el valor de cada ínidice, indica cuantas casillas ocupa la nave... por ejmplo:
 NavesA(0) = 2
 NavesA(1) = 3
 NavesA(2) = 3
 NavesA(3) = 4
 ...etc... hay dos naves de 3 casillas, 1 de 2 casillas y una de 4... (no importa el orden en que estén).
- Hay dos flotas, luego hay dos arrays con el mapa de estado de cada jugador y del estado de sus naves.

Esto se refleja en el siguiente pseudocodigo.
Código:
// Datos jugador A
arrayBytes MapJA(x,y)    //x,y expresa dos dimensiones
arrayBytes NavesA()
entero NumNavesA

// Datos Jugador B
arrayBytes MapB(x,y)
arrayBytes NavesB()
entero NumNavesB


Funcion NuevoMapa(ancho, alto, buques() )
    alojar tamaño para MapA(ancho, alto)
    alojar tamaño para MapB(ancho, alto)

    numNavesA = buques.count  
    numNavesB = buques.count

    NavesA = buques
    NavesB = buques
Fin Funcion

- Cuando se posiciona una nave en el mapa, por ejemplo la nave de 4 casillas, donde se ubique en el mapa, tales casillas ocupadas, se rellenan con el valor del índice de dicho buque. por ejemplo: 3 3 3 3. Señala que la nave de índice 3 (NavesA(3), está ubicado en esas casillas).
- Cuando se toca una casilla de la nave, en el mapa se marca (por ejemplo), 255 (tocado), y  se resta una casilla en la nave.
- Cuando la nave llega a 0 casillas, la nave está hundida, se resta una nave del jugador.
- Cuando un jugador se queda sin naves, la partida acaba.

Esas reglas se reúnen en este fragmento de pseudocódigo:
Código:
entero = Funcion Disparar(x,y, Jugador)
    byte estado

    Si (jugador = 0) luego  // A dispara a B
        estado = MapB(x,y)  // valor de estado del mapa para esa casilla.

        Si ((estado > 0) y (estado < 255) )  // se acaba de tocar un barco.
            MapB(x,y) = 255            // casilla tocada, se marca en el mapa, el nuevo estado.
            NavesB(estado) -=1       // se resta una casilla a este barco.
            Si (NavesB(estado) = 0)  //Hundido, cuando a una nave no le quedan casillas, se considera hundido
                numNaves  -=1
                Si (numNaves = 0)   // no le quedan naves. 'jugador' ganó la partida.        
                    Devolver -1
                Fin si
            Fin si            
            Devolver 1 // esto es 'tocado/hundido' jugador sigue tirando, sigue en su turno.
       fin si
       Devolver 0  // 'agua' o ya tocada.
   Sino // jugador =1, B dispara a A
      // igual que arriba pero cambiando B, por A
   Fin si
Fin funcion


El bucle principal del juego (simplificado al máximo)...
Código:
funcion MainPartida
    entero d, t, n     //d=resultado del disparo, t=turno de qué jugador.

    DecidirTamañoMapa(x,y)  // jugadores indican que tamaño tendrá el mapa.
    ArrayBytes Buques = DecidirNumeroNavesYTamaños
    NuevoMapa(x,y, buques)
    
    PosicionarFlota(buques, 0) // 0=Jugador A, se le pide que posicione sus buques en el mapa.
    PosicionarFlota(buques, 1) // 0=Jugador B,    "          "

    t = ElegirTurnoalAzar(entre 0 y 1) //t indica el jugador que tiene el turno

    // Bucle del juego hasta fin de partida.
    Hacer
        ElegirNuevasCordenadasDeDisparo(t,x,y) // se usa 't', para que el jugador específico elija las cordenadas.
        d = Disparar(x,y, t)  //t hace referencia a que mapa del jugador afecta,
                                    // con clases 't' en vez de ser un parámetro sería un objeto y disparo un método de dicho objeto.
        Si (d = -1) luego
            llamar FinalPartida("Perdiste, no te quedan naves. Ganó el jugador xxxx (que tiene el turno de disparo"
        Osi (d = 0) luego // tocado o hundido
            //CambiarTurnoJugador
            t = ValorAbsoluto(1 - t) //cambiamos el turno de jugador: esto alterna cada vez entre 0,1,0,1,0,1,0,1
        sino
            // el jugador que tiene el turno, sigue disparando hasta que falle (d=0), o no queden naves (d=-1)
        Fin si
        n += 1
    Repetir mientras ( d<> -1) //  '<>' distinto de // ó: mientras FinalPartida(d) = False

    MostrarMensaje (La partida precisó 'n' disparos para llegar a su fin...) //no es ni mucho menos la estadística que requieres,
                        // pero no cuesta constar los disparos realizados por ambos jugadores.
Fin funcion


Queda a tu esfuerzo, el resto de funciones:
 - DecidirTamañoMapa, DecidirNumeroNavesYTamaños: El trabajo de estas funciones podría quedar fijado por diseño o inicializarse con unos valores y al inicio de cada partida pedir al usuario si quiere cambiarlo.

- Con los valores previos establecidos (de las dos previas funciones), la función: NuevoMapa ya está descrita en pseudocódigo...

- PosicionarFlota: esta función se invoca dos veces. En cada una se pide al jugador que posicione sus naves en el mapa. Dicha función marcará en el mapa las casillas que ocupa cada nave, metiendo el valor de la nave que ahí se aloja.
  Debe impedirse que una nave solape otra, o que no quepa... ...luego es imprescindible que para ubicar una nave en el mapa, se consulte si la posición 'x,y' que indica el usuario como 'punto central de la nave' (o de comienzo) cabe la nave (dado su tamaño), en vertical u horizontal, contando las casillas 'agua' adhiacentes a la marcada, si cabe tanto en vertical como horizontal, luego pedir al usuario que decida la orientación, si solo cabe en una orientación se deja en esa, y al final se exige que pulse 'intro' para confirmar, o 'esc' para reposicionar en otro lado. Si pulsa 'esc', se borran las casillas marcadas para ese buque. Si pulsa intro, se avanza en el array para posicionar la siguiente nave.
  Cuando todas las naves en el array estén alojadas en el mapa, también se pedirá si confirmar con intro o si se desea cambiar una nave específica, para ello pulsar el índice de la misma....

- ElegirTurnoalAzar: esta función simplemente decide que jugador empieza a jugar. 0 = representa al jugador A, y es su turno y 1 =representa al jugador B y será su turno.
- CambiarTurnoJugador: es una función tan simple que ni se crea, se alterna siempre del uno al otro, luego una línea de código basta...
 
- ElegirNuevasCordenadasDeDisparo: Esta función es la que puede entretenerte un poco más, ya que es donde tu reparas en como operar sobre ella.
Cuando juega la máquina contra la máquina, una estrategia de disparar al azar, puede ser aceptable incialmente, sin embargo una mejor estrategia es elegir zonas y sobre zonas, una casilla en la zona... entendiendo por zonas la división del mapa en cuadrantes, del tamaño de la nave mayor, es decir supongamos que el mapa tiene 16x16 casillas y que la nave mayor ocupa 4 casillas, entonces sería útil considerar al mapa dividido en 4x4 zonas, entonces si disparas a distancias de zona, vas asegurando que tocarás la nave mayor si o sí, de forma más coherente que al azar. linea 3, linea 7, 11 y 15 verticales y horizontales. Una vez cubierto así el mapa habrás dado con todas las de 4, se divide cada zona en la mitad y así... naturalmente cuando tocas una nave, te ciñes sobre ella hasta hundirla...
  Al caso para cada jugador deberías guardar como va la estrategia. Como por ejemplo copia de donde ha disparado previamente el jugador, para no repetir disparos... es decir se elige al azar, pero si ya se disparó allí se elige otra posición.
Diseñado con objetos sería más sencillo de hacer y mantener el código.

- Disparar: Esta función evalúa sobre el mapa el resultado que afecta a la flota contra la que se dispara, y el resultado del disparo se evalúa tras dicha función como parte del bucle principal del juego.

- FinalPartida: En el pseudocódigo se usa para indicar un mensaje del resultado de la partida, pero podría trasladarse allí parte del código del bucle principal... y sería quien evaluara si al jugador le quedan naves o no...

En fin, ya tienes un planteamiento general y la distribución de funciones, ahora solo toca rellenar el código para cada función y probarlo...
3354  Foros Generales / Noticias / Re: Nokia se da cuenta de su error y lanzará un Nokia 3310 4G que podría ejecutar... en: 29 Diciembre 2017, 18:28 pm
La unión en un solo dispositivo del teléfono y el ordenador, es algo que se esperaba desde comienzo de los 90 (incluso antes), y no hay duda que es algo muy acertado, sin embargo debeiera mantenerse la separación absokuta de las características.
En un mismo dispositivo?: SÍ. compartiendo todo en común?: NO. Pero los fabricantes solo atienden a cifras de negocio, les importa un egg, la seguridad ni nada de nada. Los cambios forzados, solo lo son por quejas que pueden producir la inestabilidad de la empresa... es decir porcos o nulos, si al final los vehiculan con falsedades (como acostumbran a hacer).

En ese sentido, por tanto que vuelvan a existir teléfonos 'unSmart', es todo un paradójico avance en la seguridad. Qué necesitas seguridad ante todo?. Pasas de un dudoso Smart-phone... Qué necesitas hacer un poco de todo?. Regreso a un PC, o incluso a un miniPC.

Frente a la abochornable, insoportable, insufrible ilimitadas opciones, serivcios y programas innecesarios (para el usuario doméstico) de los PC con Microsoft al frente y en el otro frente, la nula capacidad de control auténtico (sin hacer root y jugártela con una ROM hackeada y pérdida de garantías) de los teléfonos móviles (con Google o peor con Apple), podría sacarse un término medio, donde el usuario tenga opción y control de todo, pero donde no vengan preinstalado nada inútil... que exista, vale, pero que venga preinstalado no. En fin, un dispositivo así, creo que se llevaría la palma al menos para todo usuario entendido en tecnología... y con una separación clara y definida de lo que es el teléfono y lo que es el resto. Que no venga a suceder que un maldito intruso se haga dueño del teléfono, algo solo posible cuando la fusión es absoluta. Con cierta separación en funciones, nada de eso pasaría...
3355  Foros Generales / Noticias / Re: Las universidades de EEUU al fin lo han reconocido: empezar a programar por ... en: 29 Diciembre 2017, 18:08 pm
Mal hecho...

Debieran empezar aprendiendo con pseudocodigo, sin ni siquiera tocar el ordenador.

Repartir simples papeles con los nombres d elos meses o los días d ela semana, y por ejemplo sugerirles que creen órdenes parar ordenar los meses dados en un desorden específico que el profesor (por ejemplo), escribiese en la pizarra...

El alumno, lo primero que debe aprender (de programación), es a pensar a expresar sus ideas de forma cabal y ordenada. E incidir en ello, unos 3 meses. Más adelante será solo cuestión de traducir el pseudocódigo a los términos de lenguaje que se pretenda usar para enseñar al alumno.

De todos modos, creo que lo ideal es que en la Universidad y con fines didácticos, se creara y usara un lenguaje específico para tales propósitos, el aprendizaje. Un lenguaje bastante limitado, pero que toque todos los palos (desde el manejo de datos básicos hasta estructuras complejas, desde manejo con ficheros a manejo en red (aunque sea sólo local), desde ordenar arrays hasta cifrado y compresión.
... y la razón es que los lenguajes modernos, son hoy día una auténtica jungla imposible de abarcar (ya) por nadie, entonces enfrentar a un novato a algo tan gigantesco, puede causarles frustración muy fácilmente

...esta es la razón, por la que las dos generaciones previas, aprendieron mucho mejor desde algo tan simple como el BASIC, tan denostado hoy día. A pesar de que luego los que no se profesionalizaron se quedaron en el mismo BASIC que aprendieron.

El primer lenguaje debe ser uno que permita al docente centrarse en el tema que trata de enseñar y al aprendiz centrarse en el problema para entenderlo y dominarlo, alejado de la problemática propia que encierra el propio lenguaje (abstraerse de todo lo que no sea aprender la lección en curso, de cosas por ahora innecesarias pero que consumen tiempo, esfuerzo y expectativas). A medida que se tenga un dominio práctico de dicho lenguaje académico y que se vea al alumno fluído en entender y aplicar sus conocimientos, es cuando puede pasarse a un lenguaje de producción.

...por eso hoy día las Universidades son una de las principales fuentes generadoras de frustración e incluso entre los que salen adelante de crear personas susceptibles a la ansiedad en edades muy tempranas.
3356  Foros Generales / Foro Libre / Re: Tabarnia arrasa en internet en: 28 Diciembre 2017, 20:13 pm
No es exactamente eso. La idea que no se si va en serio o no, es la siguiente:
Tu ajustas con más precisión, pero es lo de siempre. El dinero.

Pero insisto que es como digo... ya que dentro de esa misma supuesta nueva comunidad, también habrá alguna población en concreto que destaque del resto y CON LOS MISMOS ARGUMENTOS, también pretenda que sus impuestos sean solo para ellos... pero, no acabaría ahía la cosa, dentro de la misma población también hay barrios y siempre habrá uno o dos barrios más ricos, y media docena mucho más pobres, luego el problema y la solución se repiten hasta llegar a "Casalandia", donde mi sola casa sea una comunidad autónoma-país (alcaso es lo mismo de absurdo, aunque ciertamente la legalidad puede diferir), y donde mis impuestos sean solo para mi...

...la pregunta pertinente entonces es: ¿Para qué sirven los impuestos , si al final cada uno va a tener devuelta exactamente los mismos impuestos que pagó?. El fundamento de la comunidad, es que nos ayudemos entre todos, el que más gana, favoreciendo al que menos gana, y desde luego no es un favorecimiento 'gratuito'. El que más gana, lo hace por que las leyes lo permiten, porque las leyes son laxas en la forma y cantidad de conseguir riqueza, luego hay que colocar siempre los dos platillos en la balanza: el de lo que suma y el de lo que resta, y no solamente el que suma... Ahí, ese el el pozo donde acaba toda la hipocresía del 'todo para mi', del 'no quiero-queremos repartir los impuestos'... en ver solo la parte d elas leyes, donde puede enriquecerse de mil maneras a costa de los demás, pero donde se niegan en rotundo a ver donde PARTE de ello ,es devuelto a todos en forma de impuestos.

...es lo mismo de siempre, egoísmo pesetero (aunque la peseta, quede en la Historia ya como moneda aparacada, sigue procediendo de 'peso' y esto siempre estará en el presente.).
3357  Foros Generales / Foro Libre / Re: Tabarnia arrasa en internet en: 28 Diciembre 2017, 10:20 am
Yo voy a 'Casalandia', es decir a hacer de tu casa un país independiente, y la razón?. Pués ya puestos, porque sí... "...porque si vivimos en democracia, tengo 'derecho' a lo que me dé la gana, y si no, es una dictadura opresiva" .

Es la presumible respuesta, de los que creen equivocadamente que una democracia significa "hago lo que me da la gana".
3358  Programación / .NET (C#, VB.NET, ASP) / Re: Consulta 1 en: 28 Diciembre 2017, 10:11 am
Vas por mal camino. Insistes en programar sin saber lo más mínimo, ni siquiera el nombre de cosas elementales... coger un par de libros y empapartye con ello, es lo mínimo que debería hacer cualquiera, para como mínimo hablar con algo de propiedad, sin obligación de llegar a la precisión absoluta (la cual es igual de odiosa)... en fin allá tú...

---------------
El asunto que planteras, no es realmente un tema de programación, es un tema de ingenio. Tú eres capaz de guardar en un texto, solo una palabra?. o cinco palabras?, o 500 palabras?...
La cuestión puerilmente se reduce a que siempre que seas capaz de descomponerlas e interpretarlas correctamente, posible será posible...

...otra cosa es: ¿resulta conveniente?. Si el código que te quieres ahorrar, lo vas a perder descomponiendo e intrepretando únivocamente cada 'cadena', añadiendo posibilidades de error y teniendo en cuenta que precisamente todo eso ya es algo que hace el propio entorno de programación por tí entonces, la cuestión se limita a: ¿¿¿¿¿Cuál es el objetivo????.

¿No se te ocurre pensar que el propio entorno de programación tiene necesidad de distinguir (él mismo), unas cadenas de texto de otras...y... qué hará, cómo lo hará?. Intenta responderte las cosas a tí mismo antes de preguntar a nadie, la mitad de las veces (al menos), deberías ser capaz de responderte a tí mismo... y luego investigar un poco (al menos un poco), en google por tu cuenta... y sin llegar al XML, deberías encontrar que es un tema que se debió de solucionar, al poco de 'inventarse' la programación... pero solo pensando un poco por tu cuenta hubieras llegado a esa conclusión, incluso sin consuiltar nada... 

...Respóndete a tí mismo a estas preguntas: ¿Qué es un byte?. ¿Puede hacerse organizaciones de más de un byte, y si es así, cómo? (el para qué es obvio). y entonces entenderás desde los propios datos numéricos, hasta el array, las listas y diversas colecciones, las bases de datos y ficheros, etc... etc... pero tú sigue ignorando tomar un libro y leerte los fundamentos básicos, sigue de espaldas, porque tras 20 años así, seguirás tropezando, en las mismas piedras todos los días y en cosas elementales que resultan hasta ridículas de responder.
3359  Foros Generales / Noticias / Re: Los operadores podrán bloquear el nivel de cobertura en Android P en: 25 Diciembre 2017, 23:31 pm
Ahora que ya salió adelante la rotura de la neutralidad en internet, obviamente les será muy útil, para tapar el 'desfalco'... que el usuario no sepa datos realistas de su conexión, así no podrá quejarse con datos fiables y podrán responderle aquello de: "según nuestros datos, todo funciona correctamente..."
3360  Foros Generales / Noticias / Re: Las burradas tecnológicas que dirá tu cuñado en las cenas navideñas (y cómo ... en: 25 Diciembre 2017, 22:36 pm
Artículo lamentable. El autor, sin duda necesita justificarse y 'atacar' a quien no comparte su opinión.
Hay exactamente las mismas razones para lo uno como para lo otro, luego debate solo hay si uno quiere 'defender' su posición.

¿Que hay pesados?. Cierto, pero si es tu cuñado, pués algún cariño le tendrás/te tendrá, así que no llegará la sangre al río.
Páginas: 1 ... 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 [336] 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 ... 431
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines