Portál AbcLinuxu, 12. května 2025 05:24
#include <stdio.h> #include <stdlib.h> #include <string.h> #define RADKY 5 #define DELKA 256 int main(void) { char **text; int i; /* Alokace pole. */ text=(char **) malloc(RADKY*sizeof(char *)); for (i=0; i<RADKY; i++) text[i]=(char *) malloc(DELKA*sizeof(char)); /* Neco do nej dame. */ strcpy(text[0], "prvni"); strcpy(text[1], "druhy"); /* Zkusime to vytisknout. */ printf("%s", text[0]); /* Uvolneni pole. */ for (i=0; i<RADKY; i++) free(text[i]); free(text); return(0); }Místo RADKY a DELKA můžeš mít libvolnou proměnnou typu int. Nezapomeň, že dvourozměrné pole musíš uvolňovat ve dvou krocích. Snad jsem to trefil, kdyžtak napiš mail.
typedef struct { char *radek; struct *radek; } radek;(ted si nejsem jisty syntaxi) a pak postupne pridavat prvky.. no a zpetne prochazeni taky bude horor... cili jednoducha funkce v C na to neexistuje, moznosti jsou: naprogramovat si to sam, pouzit C++ (asi nejlepsi volba) nebo pouzit nejaky script jazyk
printf("Zadej pocet radku: "); scanf("%d", &radky);tak pak muj priklad funguje, staci misto RADKY napsat radky:
/* Alokace pole. */ text=(char **) malloc(radky*sizeof(char *)); for (i=0; i<radky; i++) text[i]=(char *) malloc(DELKA*sizeof(char));a je to jednodussi.
typedef struct { char *retezec; radek *dalsi; radek *predchozi; } radek;Tohle resi docela dobre zpetne prochazeni a je to myslim dobre.
typedef struct { char *retezec; radek *dalsi; radek *predchozi; } radek;by melo byt:typedef struct s_radek { char *retezec; struct s_radek *dalsi; struct s_radek *predchozi; } radek;Protoze radek neni tou dobou jeste deklarovan, ale struct s_radek jiz ano.
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.