|
Rövid sztringek
Adott a következő fejlécállomány:
myheader.h
#ifndef _MYHEADER_H #define _MYHEADER_H 1
char **foo(char **, int);
#endif /* myheader.h */
letöltés szöveges állományként
Írja meg a myheader.h állományban deklarált foo() függvényt, amely
paraméterként megkapja egy sztringeket tartalmazó tömb kezdőcímét és elemszámát! A függvény
határozza meg a tömb legrövidebb sztringjének a hosszát, számolja meg, hogy hány ilyen
hosszúságú sztring van a tömbben (n darab), majd hozzon létre egy új,
n + 1 elemű tömböt, amelynek első n eleme az az n
darab mutató legyen az eredeti tömbbeli elhelyezkedésük sorrendjében, amelyek az eredeti tömb
legrövidebb sztringjeit címzik! Az új tömb (n + 1)-edik eleme egy NULL
mutató legyen! A függvény visszatérési értéke az újonnan létrehozott mutatótömb kezdőcíme
legyen!
Megjegyzés
A függvényt helyezze a foo.c nevű állományba, és ezt az állományt küldje
be megoldásként a kiértékelő rendszernek! Megoldását az alábbi állományok segítségével
tesztelheti. Megoldásának kiértékelését a tesztelő rendszer nem feltétlenül ezeknek az
állományoknak a felhasználásával végzi!
main.c
#include <stdio.h> #include <stdlib.h> #include "myheader.h"
int main() { char *t[] = {"alma", "szilva", "korte", "eper", "meggy", "cseresznye"}; char **result = foo(t, sizeof(t) / sizeof(char *)); char **tmp; for (tmp = result; *tmp; ++tmp) printf("%s\n", *tmp); free(result);
return EXIT_SUCCESS; }
letöltés szöveges állományként
Makefile
SRCS = main.c foo.c OBJS = $(SRCS:%.c=%.o) TARGETS = main
.PHONY: clean
all: $(TARGETS)
main: $(OBJS) $(CC) $(OBJS) -o main
%.o: %.c $(CC) -Wall -c $< -o $@
clean: rm -rf $(OBJS) *~ $(TARGETS)
letöltés szöveges állományként
A példa tesztprogram kimenete
alma eper
letöltés szöveges állományként
|
|