|
Értékes tárgyak
Egy bináris állományban a rekordok szerkezetét a következő struktúrával definiáljuk:
struct subject
{
char name[40];
int credit;
};
Írjon C függvényt, amely paraméterként megkapja a bináris állomány nevét és egy kreditértéket
egész számként! A függvény hozzon létre egy új egydimenziós tömböt, amely azoknak a
tantárgyaknak az adatait tartalmazza, amelyeknek legalább akkora a kreditértékük, mint a
második paraméter! A tantárgyak a kreditértékük szerint csökkenő sorrendben szerepeljenek a
tömbben! Ha két vagy több tantárgy is azonos kredité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ű tantárgyat!
A függvény specifikációja
struct subject *foo(char *, 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 subject{ char name[40]; int credit;};struct subject *foo(char *, 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 subject *p = foo("foo.bin", 3); int i; for (i = 0; strcmp(p[i].name, "") != 0; ++i) printf("*%s* (%d)\n", p[i].name, p[i].credit); 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
|
|