|
Gyümölcsöző feladat
Egy bináris állományban a rekordok szerkezetét a következő struktúrával definiáljuk:
struct fruit
{
char name[25];
int calories;
};
Írjon C függvényt, amely paraméterként megkapja a bináris állomány nevét és két kalóriaértéket
egész számként, ahol az első kalóriaérték nem haladja meg a második értékét! A függvény hozzon
létre egy új egydimenziós tömböt, amely azoknak a gyümölcsöknek az adatait tartalmazza,
amelyeknek a kalóriaértéke a második és harmadik paraméter értéke közé esik! A gyümölcsök a
kalóriaértékük szerint csökkenő sorrendben szerepeljenek a tömbben! Ha két vagy több gyümölcs
is azonos kalóriaértékű lenne, akkor őket a nevük alapján lexikografikusan növekvő sorba
rendezze! A tömb végét egy olyan elem jelezze, ahol a név egy üres sztring, feltételezve, hogy
az állomány nem tartalmaz ilyen nevű gyümölcsöt!
A függvény specifikációja
struct fruit *foo(char *, int, int);
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!
myheader.h
#ifndef _MYHEADER_H #define _MYHEADER_H 1
struct fruit { char name[25]; int calories; };
struct fruit *foo(char *, int, int);
#endif /* myheader.h */
letöltés szöveges állományként
main.c
#include <stdio.h> #include <stdlib.h> #include <string.h> #include "myheader.h"
int main() { struct fruit *p = foo("foo.bin", 100, 200); int i; for (i = 0; strcmp(p[i].name, "") != 0; ++i) printf("*%s* (%d)\n", p[i].name, p[i].calories); free(p); 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
|
|