|
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 1struct 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.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
|
|