|
Osztódás
Írjon függvényt, amely paraméterként megkapja egy egész számokat tartalmazó tömb kezdőcímét
és elemeinek darabszámát, valamint egy n pozitív egész számot! A függvény – az
eredeti tömb módosítása nélkül – hozzon létre egy új, egész értékeket tartalmazó
tömböt, amely az eredeti tömb minden elemét n-szer tartalmazza az eredeti
sorrendben! A függvény visszatérési értéke az új tömb kezdőcíme legyen!
A függvény specifikációja
int *proliferate( int *, int, int );
Megjegyzés
A függvényt helyezze a prolif.c nevű állományba, és ezt az állományt küldje
be megoldásként a kiértékelő rendszernek! Megoldását a példa bemenetben szereplő adatokkal az
alábbi két állomány 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>
int main() { int *proliferate( int *, int, int );
for ( ; ; ) { int n, elements, i, *t, *p;
scanf( "%d %d", &n, &elements ); if ( elements == 0 ) break;
t = ( int * )malloc( elements * sizeof( int ) );
for ( i = 0; i < elements; ++i ) scanf( "%d", &t[ i ] );
p = proliferate( t, elements, n );
for ( i = 0; i < n * elements; ++i ) { if ( i > 0 ) putchar( ' ' ); printf( "%d", p[ i ] ); } putchar( '\n' );
free( p ); free( t ); } return EXIT_SUCCESS; }
letöltés szöveges állományként
Makefile
CC = gcc OBJS = main.o prolif.o TARGETS = main
all: $(TARGETS)
main: main.o prolif.o $(CC) main.o prolif.o -o main
main.o: main.c $(CC) -c main.c
prolif.o: prolif.c $(CC) -c prolif.c
clean: rm -rf $(OBJS) *~ $(TARGETS)
letöltés szöveges állományként
Példa bemenet
3 3 1 2 3 1 5 10 20 -30 40 50 0 0
letöltés szöveges állományként
A példa bemenethez tartozó kimenet
1 1 1 2 2 2 3 3 3 10 20 -30 40 50
letöltés szöveges állományként
|
|