1. 程式人生 > >函數和數組

函數和數組

== cti color args 循環 原型 二維數組 spa http

1. 函數和一維數組

數組作為參數傳遞,傳遞的是數組第一個元素的地址,所以屬於引用傳遞

對於Java相同,Java冒泡排序

    public static void main(String args[]) {
        int arr[] = new int[] {9, 1, 2, 3, 4, 7, 8, 6, 5 };
        sort(arr);
        for(int i=0; i<arr.length; i++) {
            System.out.println(arr[i]);
        }
    }

    
public static void sort(int arr[]) {//冒泡排序 for (int x= 0; x<arr.length; x++) { for (int y=0; y<arr.length-1; y++) { if (arr[y] > arr[y+1]) { int temp; temp = arr[y]; arr[y] = arr[y+1]; arr[y
+1] = temp; } } } }

重要的兩個恒等式

arr[i] == *(arr + i);

&arr[i] == arr + i;

數組處理函數常用的編寫方式:

如果要修改數組,函數原型如下:

void f_modify(double ar[], int n);

如果不修改數組,函數原型如下

void _f_no_change(const double ar[], int n);

使用數組區間的函數

技術分享圖片

sum_arr函數將pt指向要處理的第一個元素的指針,即將*pt的值加到total 中,然後通過循環來更新pt,使之指向下一個元素,只要pt不等於end,過程繼續進行

2. 函數和二維數組

arr[r][c] == *(*(arr + r) + c)

二維數組作為函數參數傳遞時的兩種函數原型

int function(int (*arr)[c], int r);

int function(int arr[][c], int r);

技術分享圖片

函數和數組