Programozó versenyek

Programozási nyelvek 1, 2019. április 10., Sz16 ZH

2019. április 10. 16:05 – 2019. április 10. 17:50

Unalmas kilométerek

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

myheader.h

  1. #ifndef _MYHEADER_H
  2. #define _MYHEADER_H 1
  3. typedef struct
  4. {
  5.     int length;
  6.     int count;
  7. } ELEM;
  8. ELEM foo(const char *);
  9. #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 sztringet! A sztring egy túraútvonalat ír le, melyben a benne szereplő egyenlőségjel karakterek ('=') az útvonal egy-egy kilométerét jelölik. Az útvonalon lévő látnivalókat csillag karakterek ('*') jelzik a sztringben. A függvény határozza meg, hogy mekkora a legnagyobb olyan távolság a túraútvonalon, ahol nincsen semmilyen látnivaló, valamint azt, hogy hány ilyen hosszú része létezik az útvonalnak, és adja vissza ezt a két értéket egy ELEM típusú struktúrában! Ha az útvonalnak egyáltalán nincsen unalmas része, akkor a darabszám értéke 0 legyen (lásd a példát)!

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 *t[] = {"===", "=*=", "*=*", "*==", "==*", "***", "**=", "=**"};
  7.     int i;
  8.     for (i = 0; i < sizeof(t) / sizeof(char *); ++i)
  9.     {
  10.         ELEM tmp = foo(t[i]);
  11.         printf("%d %d\n", tmp.length, tmp.count);
  12.     }
  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. 3 1
  2. 1 2
  3. 1 1
  4. 2 1
  5. 2 1
  6. 0 0
  7. 1 1
  8. 1 1
letöltés szöveges állományként
Debreceni Egyetem, Informatikai Kar, v. 2019.03.01.