数组结合指针可以实现很多有趣的功能,比如下面这个程序:

假设数组为 : 12345

如果左移一次即为:23451 ,依次类推

如果右移一次即为:51234 ,依次类推

翻转则为:54321

我们来实现下这个程序:

#include

#include

#include

#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则为翻转

本文同步分享在 博客“Engineer-Bruce_Yang”(CSDN)。

如有侵权,请联系 support@oschina.cn 删除。

本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐