|
Permutációk
Adott a következő fejlécállomány:
myheader.h
#ifndef _MYHEADER_H #define _MYHEADER_H 1
int foo(int *);
#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 megkapja egy nemnegatív egészeket tartalmazó tömb kezdőcímét! A tömbben
található értékes, feldolgozandó elemeket (melyeknek a száma n) a tömbben egy 0-s
érték zárja le. A függvény döntse el, hogy a tömb értékes elemei az 1-től n-ig tartó
egész számsorozat permutációját alkotják-e, és logikailag igaz értéket adjon vissza, ha igen,
egyébként pedig hamisat! Amennyiben a tömb nem tartalmaz egyetlen értékes elemet sem a 0-s
szám előtt, a függvény akkor is logikailag igaz értéket adjon vissza! Ügyeljen rá, hogy a
paraméterként megkapott tömb elemei ne változzanak, se a sorrendjük, se az értékük!
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() { int t[] = {3, 4, 1, 2, 0}, i; for (i = 0; i < sizeof(t) / sizeof(int); ++i) printf("%s\n", foo(&t[i]) ? "YES" : "NO"); 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
YES NO YES NO YES
letöltés szöveges állományként
|
|