C語言中陣列的使用詳解

2022-09-21 21:30:27 字數 3809 閱讀 4472

目錄

陣列型別 陣列名[陣列大小]

int arr[5] = ;

//arr[0]:1

//arr[1]:2

//arr[2]:3

//arr[3]:4

//arr[4]:5

int arr[5] = ;

//arr[0]:1

//arr[1]:2

//arr[2]:3

//arr[3]:0

//arr[4]:0

實際開發中,通常採用部分元素賦初值的方法對陣列元素進行初始化,如:int arr[100]=;

int arr = ;

定義陣列時,如果後面跟有初始化列表,並且初始化列表中的值的個數就是預期的陣列大小,則可省略括號中的陣列大小。

#include

int main(void)

//求平均值、求最大值、最小值

sum = 0;

max = arr[0];

min = arr[0];

for(i=0; i<10; i++)

if(min>arr[i])

}printf("平均值為:%.2f", sum/10.0);

printf("最大值為:%d", max);

printf("最小值為:%d", min);

}#include

int main(void);

int i, temp;

//陣列逆置

for(i=0; i<10/2; i++)

//輸出

for(i=0; i<10; i++)

} 4.3.1 氣泡排序

排序:5, 7, 1, 4, 9, 2, 10, 3, 8, 6

第一次:5,1,4,7,2,9,3,8,6,|10

第二次:1,4,5,2,7,3,8,6,|9,10

第三次:1,4,2,5,3,7,6,|8,9,10

第四次:1,2,4,3,5,6,|7,8,9,10

第五次:1,2,3,4,5,|6,7,8,9,10

第六次:1,2,3,4,|5,6,7,8,9,10

第七次:1,2,3,|4,5,6,7,8,9,10

第八次:1,2,|3,4,5,6,7,8,9,10

第九次:1,|2,3,4,5,6,7,8,9,10

#include

int main(void);

int i, j, temp;

//氣泡排序

for(i=0; i<10-1; i++)}}

//輸出

for(i=0; i<10; i++)

} 4.3.2 選擇排序 選擇列表中的最小值與未排序列表中的第乙個值互換位置。排序:5, 7, 1, 4, 9, 2, 10, 3, 8, 6

第一次:1,|7,5,4,9,2,10,3,8,6

第二次:1,2,|5,4,9,7,10,3,8,6

第三次:1,2,3,|4,9,7,10,5,8,6

第四次:1,2,3,4,|9,7,10,5,8,6

第五次:1,2,3,4,5,|7,10,9,8,6

第六次:1,2,3,4,5,6,|10,9,8,7

第七次:1,2,3,4,5,6,7,|9,8,10

第八次:1,2,3,4,5,6,7,8,|9,10

第九次:1,2,3,4,5,6,7,8,9,|10

#include

int main(void);

int i, j, min, temp;

//選擇排序

for(i=0; i<10-1; i++)

}if(min != j)

}//輸出

for(i=0; i<10; i++)

} 4.3.3 直接插入排序

每次都無序列表中選擇第乙個元素,與有序列表中最後乙個元素開始逐一比較,在比它小的元素後面插入該元素。

排序:5, 7, 1, 4, 9, 2, 10, 3, 8, 6

第一次:5,7,|1, 4, 9, 2, 10, 3,程式設計客棧 8, 6

第二次:1,5,7,|4, 9, 2, 10, 3, 8, 6

第三次:1,4,5,7,|9, 2, 10, 3, 8, 6

第四次:1,4,5,7,9,|2, 10, 3, 8, 6

第五次:1,2,4,5,7,9,|10, 3, 8, 6

第六次:1,2,4,5,7,9,10,|3, 8, 6

第七次:1,2,3,4,5,7,9,10, | 8, 6

第八次:1,2,3,4,5,7,8,9,10, |6

第九次:1,2,3,4,5,6,7,8,9,10

#include

int main(void);

int i, j, temp;

//直接插入排序

for(i=1; i<10; i++)

arr[j+1] = temp;

}//輸出

for(i=0; i<10; i++)

} 二維陣列就是存放一維陣列的一維陣列。本質上可以理解為二維陣列就是乙個一維陣列,只不過這個一維陣列裡面的每乙個元素都是乙個一維陣列。

int arr[3][4];//相當於定義乙個3行4列的二維陣列

相當於乙個長度為3的一維陣列,這個一維陣列裡面每個元素的長度是:長度為4的整形一維陣列。

5.2.1 全部初始化 按行全部賦初值

int arr[2][3] = , };

順序全部賦初值

int arr[2][3] = ;

5.2.2 部分初始化

按行部分賦初值

int arr[2][3] = , };

順序部分賦初值

int arr[3][4] = ;

5.2.3 省略長度初始化

可省略行數,不可省略列數。按行

int arr[3] = , , };//arr[3][3]

int brr[3] = , };//brr[2][3]

按順序int arr[3] = ;//arr[2][3]

#include

int main(void);

int i, j;

for(i=0; i<3; i++)

printf("\n");}}

#include

int main(void)

for(j=0; j<4; j++)

}//求每一科的平均成績

for(i=0; i<3; i++)

**er1[i] = sum/4.0;

}//求每個人的平均成績

for(i=0; i<4; i++)

**er2[i] = sum/3.0;

}for (i=0; i<3; i++)

printf("的平均成績為:%.2f\n", **er1[i]);

}printf("------------------------\n");

for (i=0; i<4; i++)

printf("的平均成績為:%.2f\n", **er2[i]);

}return 0;

} char ch[5] = ;

char s1[6] = ;

char s2[6] = "abcde";

//s1與s2初始化效果相同

char str[100];

//輸入 ni hao a

scanf("%s", str);

//列印 ni

printf("%s\n", str);

char str[100];

gets(str);

p本文標題: c語言中陣列的使用詳解

本文位址:

C語言中realloc 使用詳解

realloc函式用來為ptr重新分配大小為size的一塊記憶體,看似很簡單,在使用過程中卻會發生各種錯誤。函式形式為 void realloc void ptr,size t new size 最近在網上檢視了一些資料,在glibc中沒有找到具體的實現 有人找到了可以發給我,ladd.cn gma...

詳解C語言中的陣列指標與指標陣列

詳解陣列指標與指標陣列 陣列指標 一 區分 首先我們需要了解什麼是陣列指標以及什麼是指標陣列,如下圖 int p 5 int p 5 陣列指標的意思即為通過指標引用陣列,p先和 結合,說明了p是乙個指標變數,指向乙個大小為5的陣列。所以,int p 5 即為乙個陣列指標。int p 5 則是乙個大小...

C語言中的sscanf 函式使用詳解

sscanf 從乙個字串中讀進與指定格式相符的資料.函式原型 int sscanf string str,string fmt,mixed var1,mixed var2 int scanf const char format argument 說明 sscanf與scanf類似,都是用於輸入的,只...