C語言實現陣列的迴圈左移,右移,翻轉
阿新 • • 發佈:2019-01-09
陣列結合指標可以實現很多有趣的功能,比如下面這個程式:
假設陣列為 : 12345
如果左移一次即為:23451 ,依次類推
如果右移一次即為:51234 ,依次類推
翻轉則為:54321
我們來實現下這個程式:
執行結果:#include <stdio.h> #include <stdlib.h> #include <string.h> #define NR(x) (sizeof(x)/sizeof(x[0])) //陣列左移 int buffer_left_move(int *buffer , int buf_len) { int i ; char tmp = buffer[0]; for(i = 1 ; i < buf_len ; i++) { buffer[i-1] = buffer[i] ; } buffer[buf_len-1] = tmp ; } //陣列右移 int buffer_right_move(int *buffer , int buf_len) { int i ; char tmp = buffer[buf_len - 1]; for(i = buf_len ; i > 0 ; i--) { buffer[i] = buffer[i-1] ; } buffer[0] = tmp ; } //陣列翻轉 int buffer_turn_over(int *buffer , int buf_len) { int size = buf_len ; int i , tmp; for(i = 0 ; i < size/2 ; i++) { tmp = buffer[i] ; buffer[i] = buffer[size-1-i] ; buffer[size-1-i] = tmp; } } //列印陣列 void print_buffer(int *buffer, int buf_len) { int i ; system("cls"); printf("please input \'a' or \'b' or \'w' \n"); for(i = 0 ; i < buf_len ; i++) { printf("%d",buffer[i]); } putchar('\n'); } int main(void) { int buffer[5] = {1,2,3,4,5} ; print_buffer(buffer,NR(buffer)); while(1) { switch(getch()) { //左邊 case 'a': buffer_left_move(buffer,NR(buffer)) ; print_buffer(buffer,5); break ; //右邊 case 'd': buffer_right_move(buffer,NR(buffer)); print_buffer(buffer,5); break ; //翻轉 case 'w': buffer_turn_over(buffer,NR(buffer)) ; print_buffer(buffer,5); break ; } } return 0 ; }
please input 'a' or 'b' or 'w'
12345
按下a為不斷左移,按下d為不斷右移,按下w則為翻轉