数据结构之数组翻转的实现方法
更新时间:2017年10月12日 08:44:18 作者:爱思考的小鸟
这篇文章主要介绍了数据结构之数组翻转的实现方法的相关资料,这里用几种实现方法来实现这样的功能,需要的朋友可以参考下
数据结构之数组翻转的实现方法
以下为实现数组翻转的方法:
1.用c语言实现的版本
#include<stdio.h> #define M 20 void fun(int *x,int n) { int *i, *j, *p, m=n/2; i = x; j = x+n-1; p = x+m; for( ; i<p; ++i,--j) { int t = *i; *i = *j; *j = t; } } void main() { int i,a[M],n; printf("Enter n(n<20):\n"); scanf("%d",&n); printf("The original array:\n"); for(i=0; i<n; ++i) { scanf("%d", a+i); } fun(a,i); printf("\nThe array inverted:\n"); for(i=0; i<n; ++i) { printf("%d ", *(a+i)); } printf("\n"); }
2. 用c++实现的版本
#include<iostream> #define M 20 void fun(int *x,int n) { int *i, *j, *p, m=n/2; i = x; j = x+n-1; p = x+m; for( ; i<p; ++i,--j) { std::swap(*i,*j); } } void main() { <span style="white-space:pre"> </span>int i,a[M],n; <span style="white-space:pre"> </span>std::cout<<"Enter n(n<20):"<<std::endl; std::cin>>n; std::cout<<"The original array:"<<std::endl; <span style="white-space:pre"> </span>for(i=0; i<n; ++i) { std::cin>>*(a+i); } <span style="white-space:pre"> </span> fun(a,i); std::cout<<std::endl<<"The array inverted:"<<std::endl; <span style="white-space:pre"> </span>for(i=0; i<n; ++i) { std::cout<<*(a+i)<<" "; } std::cout<<std::endl; }
效果图如下:
3. 用PHP实现的版本
<?php $arrOrigin = array(1,2,3,4,5,6,7,8,9,10); $arrReverse = array_reverse($arrOrigin); echo '原始数组:'; print_r($arrOrigin); echo '<br/>'; echo '翻转后的数组:'; print_r($arrReverse); ?>
结果如下所示:
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
相关文章
C++中sort()函数和priority_queue容器中比较函数的区别详析
C++中sort()和priority_queue都能自定义比较函数,其中sort()自定义的比较函数比较好理解,priority_queue中自定义的比较函数的效果和sort()是相反的,这篇文章主要给大家介绍了关于C++中sort()函数和priority_queue容器中比较函数的区别的相关资料,需要的朋友可以参考下2023-03-03
最新评论