1. 程式人生 > >將一個數組中的資料按相反的順序儲存

將一個數組中的資料按相反的順序儲存

指標

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;
}