將一個數組中的資料按相反的順序儲存
阿新 • • 發佈:2019-01-31
指標
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; }