|
Mértani sorozat
Adott a következő fejlécállomány:
myheader.h
#ifndef _MYHEADER_H #define _MYHEADER_H 1
int *foo(int, int, int, 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 – ilyen sorrendben – megkap négy egész számot: egy kizárólag egész
értékekből álló mértani sorozat első elemét, a sorozat kvóciensét, továbbá egy n és
egy m egészet, ahol 1 ≤ n ≤ m
teljesül! A függvény állítson elő egy új, egész típusú tömböt, amely a paraméterek által
meghatározott mértani sorozatnak az n-edik elemtől az m-edik elemig tartó
részsorozatát tartalmazza, és adja vissza annak memóriabeli kezdőcímét!
Egy mértani sorozat i-edik elemét a következő módon határozhatja meg:
ai = a1 · qi – 1,
ahol a1 a sorozat első eleme, ai a sorozat
i-edik eleme, i az i-edik elem indexe
(i ≥ 1), q pedig a sorozat kvóciense.
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 a1, q, n, m; while(scanf("%d %d %d %d", &a1, &q, &n, &m) != EOF) { int *res = foo(a1, q, n, m), i; for (i = 0; i < m - n + 1; i++) { if (i > 0) putchar(' '); printf("%d", res[i]); } putchar('\n'); free(res); } 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
Példa bemenet
1 1 1 10 1 2 1 10 5 3 5 6
letöltés szöveges állományként
A példa tesztprogram kimenete
1 1 1 1 1 1 1 1 1 1 1 2 4 8 16 32 64 128 256 512 405 1215
letöltés szöveges állományként
|
|