|
Forgatás
Írjon függvényt, amely paraméterként megkapja egy egész számokat tartalmazó tömb kezdőcímét
és a tömb elemeinek számát, valamint egy n nemnegatí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 számokat
tartalmazó tömböt, amely az eredeti tömbre alkalmazott n-szeri jobbra forgatás
eredményét tartalmazza! 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 *rotate( int *, int, int );
Megjegyzés
A függvényt helyezze a rotate.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 *rotate( int *, int, int );
for ( ; ; ) { int elements, rot, i, *t, *p;
scanf( "%d %d", &rot, &elements ); if ( elements == 0 ) break;
t = ( int * )malloc( elements * sizeof( int ) );
for ( i = 0; i < elements; ++i ) scanf( "%d", &t[ i ] );
p = rotate( t, elements, rot );
for ( i = 0; i < 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 rotate.o TARGETS = main
all: $(TARGETS)
main: main.o rotate.o $(CC) main.o rotate.o -o main
main.o: main.c $(CC) -c main.c
rotate.o: rotate.c $(CC) -c rotate.c
clean: rm -rf $(OBJS) *~ $(TARGETS)
letöltés szöveges állományként
Példa bemenet
0 3 1 2 3 1 3 1 2 3 2 3 1 2 3 3 3 1 2 3 4 3 1 2 3 5 3 1 2 3 0 0
letöltés szöveges állományként
A példa bemenethez tartozó kimenet
1 2 3 3 1 2 2 3 1 1 2 3 3 1 2 2 3 1
letöltés szöveges állományként
|
|