将一个数组中的数据按相反的顺序存储

指针

int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 }
处理完后,数组内容变成{0,9,8,7,6,5,4,3,2,1}

实现思想:1与0交换,2与9交换,3与8交换......
内容交换

#define _CRT_SECURE_NO_WARINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
void reversearr(int* left, int* right)
{
    assert (left != null);
    assert (right != null);

    while (left < right)
    {
        int tmp = *left;
        *left = *right;
        *right = tmp;
        left++;
        right--;
    }
}
void printarr(int arr[], int sz)//数组传参,传的就是地址  int arr[]—>int* arr
{
    int i = 0;
    for (i = 0; i < sz; i++)
    {
        printf("%d ", *(arr+i));
    /*    printf("%d ", arr[i]);*/
    }
}
int main()
{
    int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };
    int sz = sizeof(arr) / sizeof(arr[0]);    
    reversearr(arr, arr+sz-1);//arr+sz-1—最后一个元素的地址—>内容交换
    printarr(arr, sz);//打印元素
    system("pause");
    return 0;
}

猜你喜欢

转载自blog.csdn.net/TheWindRisesll/article/details/81255601