Programozó versenyek

Magas szintű programozási nyelvek 1, 2015. június 2., K14 ZH

2015. június 2. 14:00 – 2015. június 2. 17:45

Minden kezdet nehéz

Adott a következő fejlécállomány:

myheader.h

  1. #ifndef _MYHEADER_H
  2. #define _MYHEADER_H 1
  3. char **foo(char *[], int, int, char);
  4. #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ó kétdimenziós tömb kezdőcímét, sorainak és oszlopainak számát, valamint egy karaktert! A függvény járja be a kétdimenziós tömböt sorfolytonosan, és a bejárás során érintett, a paraméterként megkapott karakterrel kezdődő sztringek címeit helyezze el egy újonnan létrehozott egydimenziós tömbben! Az új tömb utolsó eleme egy NULL mutató, a függvény visszatérési értéke pedig az új 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

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include "myheader.h"
  4. int main()
  5. {
  6.     char *m[2][3] = {{"galambtojas", "furjtojas", "kakukktojas"},
  7.                      {"kakastojas",  "tyuktojas", "okostojas"}};
  8.     char **p = foo(&m[0][0], 2, 3, 'k');
  9.     int i;
  10.     for (i = 0; p[i] != NULL; ++i)
  11.         printf("*%s*\n", p[i]);
  12.     free(p);
  13.     return EXIT_SUCCESS;
  14. }
letöltés szöveges állományként

Makefile

  1. SRCS = main.c foo.c
  2. OBJS = $(SRCS:%.c=%.o)
  3. TARGETS = main
  4. .PHONY: clean
  5. all: $(TARGETS)
  6. main: $(OBJS)
  7. $(CC) $(OBJS) -o main
  8. %.o: %.c
  9. $(CC) -Wall -c $< -o $@
  10. clean:
  11. rm -rf $(OBJS) *~ $(TARGETS)
letöltés szöveges állományként

A példa tesztprogram kimenete

  1. *kakukktojas*
  2. *kakastojas*
letöltés szöveges állományként
Debreceni Egyetem, Informatikai Kar, v. 2019.03.01.