|
Unalmas kilométerek
Adott a következő fejlécállomány:
myheader.h
#ifndef _MYHEADER_H #define _MYHEADER_H 1
typedef struct { int length; int count; } ELEM;
ELEM foo(const char *);
#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
#include <stdio.h> #include <stdlib.h>
#include "myheader.h"
int main() { char *t[] = {"===", "=*=", "*=*", "*==", "==*", "***", "**=", "=**"}; int i; for (i = 0; i < sizeof(t) / sizeof(char *); ++i) { ELEM tmp = foo(t[i]); printf("%d %d\n", tmp.length, tmp.count); } 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
3 1 1 2 1 1 2 1 2 1 0 0 1 1 1 1
letöltés szöveges állományként
|
|