|
Keresés sztringtömbben
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 megkap egy sztringeket tartalmazó egydimenziós tömböt és annak az elemszámát! A
függvény határozza meg az első olyan tömbbeli sztringet, amely lexikografikusan nem előzi meg
a rákövetkezőjét, és készítsen erről a sztringről egy másolatot! Ha ilyen nincs, akkor az
utolsó sztringről készítsen másolatot! A függvény a másolandó sztringet ne módosítsa,
visszatérési értéke pedig a másolat 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[] = {"abcde", "hijklm", "fg"}; char *p = foo(t, 3); printf("%s\n", p); free(p); 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
hijklm
letöltés szöveges állományként
|
|