|
Rövid sztringek
Adott a következő fejlécállomány:
myheader.h
#ifndef _MYHEADER_H#define _MYHEADER_H 1char **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.cOBJS = $(SRCS:%.c=%.o)TARGETS = main.PHONY: cleanall: $(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
almaeper
letöltés szöveges állományként
|
|