Programozó versenyek

Magas szintű programozási nyelvek 1, 2018. május 15., K16 ZH

2018. május 15. 16:35 – 2018. május 15. 18:20

A leghosszabb sor

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

myheader.h

  1. #ifndef _MYHEADER_H
  2. #define _MYHEADER_H 1
  3. char *foo(FILE *);
  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 megkap egy megnyitott szöveges állományt! A függvény határozza meg és adja vissza az állomány leghosszabb sorát (a záró újsor karakter nélkül)! Ha több egyforma hosszúságú sor is megfelelne a kritériumnak, akkor az elsőt! Ha az állomány egyetlen karaktert sem tartalmaz, akkor üres sztringet adjon vissza a függvény! A függvény minden esetben foglaljon memóriaterületet a megtalált sztring számára!

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.     FILE *f = fopen("sample.txt", "r");
  7.     char *line = foo(f);
  8.     fclose(f);
  9.     printf("*%s*\n", line);
  10.     free(line);
  11.     return EXIT_SUCCESS;
  12. }
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 sample.txt állomány tartalma

  1. Ez egy sor.
  2. Picike sor.
  3. Ez a leghosszabb sor.
  4. Ez is egy sor.
letöltés szöveges állományként

A példa tesztprogram kimenete

  1. *Ez a leghosszabb sor.*
letöltés szöveges állományként
Debreceni Egyetem, Informatikai Kar, v. 2019.03.01.