FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Problemas con memoria dinamica
Hola amigos, esto es C pero no sabia donde ponerlo.
El caso es que estoy intentando crearme un pequeño codigo al que le diga el numero de columnas y filas y las palabras a colocar y que me cree una sopa de letras con ellas. El codigo lo encontre por internet pero no usaba memoria dinamica asi que lo he modificado y antes de modificarlo iba bien pero ahora me da errores al intentar añadir las palabras y al intentar rellenar la sopa de letras y estoy seguro de que estoy haciendo algo mal al trabajar con los punteros de la memoria que he obtenido pero no se que. ¿pueden ayudarme? Este es el codigo: Código PHP:
|
#2
|
||||
|
||||
Cita:
No estaría mal que pusieras el código original también.
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código Únete al grupo Teaming clubdelphi | Colabora mediante Paypal Última edición por Casimiro Notevi fecha: 13-09-2015 a las 20:00:52. |
#3
|
||||
|
||||
Lo saque de aqui pero vamos que lo que hice fue cambiar por memoria dinamica los arrais y permitir decidir al usuario el tamaño de la sopa de letras, el numero de palabras a colocar, y cuales serán esas palabras y de paso quité alguna variable global:
¿Como crear una sopa de letras en C? | Yahoo Respuestas |
#4
|
||||
|
||||
Vale, pero ¿qué error tiene y dónde?
|
#5
|
||||
|
||||
Pues de momento si pongo que la sopa será de 8x8 y que colocaré 3 palabras, al meter la tercera palabra crashea y si no lo hace lo hace al inicializar con \0 la sopa. Son fallos seguro porque no estoy haciendo algo bien con el tema de punteros o con la memoria dinamica.
|
#6
|
||||
|
||||
En tu bucle principal pides palabras sin haber seresvado el espacio para todas elles y "peta"
Mira esta modificación a tu código respetando más o menos su estructura: Código PHP:
|
#7
|
||||
|
||||
tienes razon, el codigo donde acomodo las palabras estaba ejecutandose antes de terminar de allocar toda la memoria jajaja.
Ahora me queda crear algo asi como un RandomSuffle que vaya probando todas las combinaciones posibles hasta encontrar una y si las prueba todas y no da con una valida pues que avise con un error. Prueben a crear una sopa de por ejemplo 5x5 y agregen una palabra de 6 letras y veran que no sale nunca del while: Código PHP:
Mi idea es algo asi: Código PHP:
Código PHP:
Uso el mismo método para la orientacion. Código PHP:
Si cabe tengo que comprobar que case con las letras que ya haya de otras palabras. Para ello tengo que comprobar con un for si hay alguna letra y comprobar que se corresponda. Dependiendo de la orientacion tendré que comprobar que no desborde el array tampoco. Todo eso está hecho en el movil y aun no lo he probado, solo fue una idea que me vino estando fuera y lo hice en el movil para no olvidarlo pero ¿que opinais? ¿algo mejor que eso? |
#8
|
||||
|
||||
barajar filas de un array multidimensional
Buenas amigos, estoy intentando barajar las filas de un array multidimensional y no soy capaz de dar con el modo. Ahora mismo lo tengo asi:
Código PHP:
Estoy muy perdido en esto ¿alguien puede ayudarme? |
#9
|
||||
|
||||
Hola aguml.
Cita:
Por otro lado, si envias un arreglo bidimensional como argumento, deberás especificar al menos el tamaño de la segunda dimensión. Pero sinceramente no sé si interpreté correctamente lo que queres hacer... Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#10
|
||||
|
||||
Tenias razón, al crearlo con memoria dinámica ya va perfecto.
Eso cuando lo termine formará parte del código de lo de la sopa de letras. Actualmente hay un bucle en el que dx y dy que son los deltas se calculan con rand. Con esto que he hecho la idea es que pruebe todas las combinaciones válidas sin repetirlas. Esto lo tendría que hacer con todas las coordenadas x e y de la sopa de letras hasta que encuentre una válida o hasta que las pruebe todas y si no se encuentra una válida avise. Actualmente como esta en el código de la sopa de letras se podría quedar en un bucle infinito si no existiese una posición válida. |
#11
|
||||
|
||||
Asi ha quedado:
Código PHP:
|
#12
|
||||
|
||||
Bueno amigos, ya tengo el codigo funcionando y va mejor de lo que pensaba jajaja. Solo tengo una duda y es que para obtener memoria y para liberarla uso unas funciones que son copias casi identicas a excepcion del tipo de retorno y del tipo de un parametro de entrada.
Aqui las funciones: Código PHP:
|
#13
|
||||
|
||||
Yo diría que esa función de Liberarmemoriacadenas no sirve para nada.
Además devuelve null Simplemente liberas la variable, no recuerdo si es variable.free o free(variable) o freeandnil(variable) |
#14
|
||||
|
||||
Bueno, he estado pasandolo todo a C++Builder y la parte de la memoria dinamica me tiene mareado. Esto me funciona pero no se si hago algo mal:
Código PHP:
Código PHP:
Código PHP:
Y para liberar memoria hago asi: Código PHP:
Última edición por aguml fecha: 18-09-2015 a las 11:11:07. |
#15
|
||||
|
||||
Lo que he dicho antes, LiberarMemoria no sirve para nada.Te basta con free(dir)
|
#16
|
||||
|
||||
es que no estoy usando ahora malloc, estoy usando new por lo que tengo que liberar con delete. No estoy muy convencido de que liberando el puntero de punteros se libere toda la memoria allocada para cada puntero. ¿Seguro?
|
#17
|
||||
|
||||
Estás mezclando C y C++ bueno, pues déjalo así si libera correctamente.
|
#18
|
||||
|
||||
Hola aguml.
Para liberar la memoria ocupada por una matríz dinámica, básicamente tenes que recorrerla por filas e ir liberando objetos y por último liberar el arreglo. Con new (C++): Código PHP:
Código PHP:
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#19
|
||||
|
||||
Gracias amigo. Ahora me queda una duda. ¿que diferencia de funcionamiento tienen estos dos codigos?
Código PHP:
Código PHP:
|
#20
|
||||
|
||||
Hola aguml.
En base, no existen arreglos bidimensionales en C/C++. Lo que existen son arreglos unidimensionales de elementos, donde cada uno de ellos es un arreglo. El operador delete sin los corchetes se utiliza para liberar la memoria ocupada por un objeto, vg.: Código PHP:
Código PHP:
Código PHP:
El caso erroneo inverso sería: Código PHP:
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 22-09-2015 a las 19:46:52. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Array dentro de un Array | Holger | PHP | 4 | 03-01-2012 17:27:44 |
Multidimensional arrays | nemesis | JAVA | 1 | 12-10-2008 01:07:42 |
problemas con array o array | noodle_ | OOP | 7 | 19-06-2008 22:30:57 |
Como Asignar Variable Tipo Array de Tform a otro Array del Mismo tipo | morfeo21 | Varios | 5 | 17-08-2004 17:39:51 |
FFT multidimensional | i.larranaga | Varios | 0 | 04-02-2004 11:51:49 |
|