用C语言实现数组反序

本文介绍了如何使用C语言来实现数组的反序操作。通过给出的代码示例,展示了将1到5的数组反序为5到1的具体实现过程,并提供了运行结果。
摘要由CSDN通过智能技术生成

题目:

比如输入:数组是1,2,3,4,5

反序后的结果是:5,4,3,2,1

 

实现代码如下

#include <stdio.h>
//用数组反序数组
void reserve1(int a[],int n){
	int m=(n+1)/2;
	int i=0;
	for(i;i<m;i++){
	  int j=n-1-i;
	  int temp=a[i];
	      a[i]=a[j];
	      a[j]=temp;
	}
}
//用指针进行反序数组
void reserve2(int *a,int n){
	int *p,*q,*length;
	int m;
	m=(n+1)/2;
	p=a;
//	length=(a+n+1)/2;   //这个地方不是length=(n+1)/2,要记得加上数组的首地址,不要写成这样(a+n+1)/2,
	                    //因为不能对a进行操作,只能进行偏移
	length=a+m;
	q=a+n-1;
	for(;p<length;p++,q--){
	   int temp=*p;
	       *p=*q;
	       *q=temp;
	}	
}
void main() { 
	int a[5]={1,2,3,4,5};
	int *p;
	p=a;
//	for(p;p<a+5;p++){
//	  printf("%d",*p);
//	}
	int length;
	len
  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码莎拉蒂 .

你的鼓励是我最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值