|
Unalmas kilométerek
Adott a következő fejlécállomány:
myheader.h
#ifndef _MYHEADER_H#define _MYHEADER_H 1typedef 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.cOBJS = $(SRCS:%.c=%.o)TARGETS = main.PHONY: cleanall: $(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 11 21 12 12 10 01 11 1
letöltés szöveges állományként
|
|