首页 > 编程知识 正文

c语言数组初始化的三种方式,c语言定义数组并初始化

时间:2023-05-06 05:38:54 阅读:235238 作者:1597

#include<stdio.h>int main(){int array[10];//创建char ch[10];int n = 10;int arr1[n] = {0};//err []必须为常量或者常量表达式return 0;}

int array[10] = { 1, 2, 3 };//创建并初始化//不完全初始化,剩余元素默认初始化为0int arr2[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };//完全初始化int arr3[10] = { 0 };int arr4[] = { 1, 2, 3, 4, 5 };//不指定大小char ch1[] = { 'a', 'b', 'c', 'd' };//4个元素char ch2[] = "abcd";//5个元素 默认带printf("%dn", sizeof(ch1));//4printf("%dn", sizeof(ch2));//5printf("%dn", strlen(ch1));//随机值printf("%dn", strlen(ch2));//4

输出结果:

#include<stdio.h>int main(){int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8 };int i = 0;int sz = sizeof(arr) / sizeof(arr[0]);for (i = 0; i < sz; i++){printf("%d ", arr[i]);}return 0;}


#include<stdio.h>int main(){int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8 };int i = 0;int sz = sizeof(arr) / sizeof(arr[0]);for (i = 0; i < sz; i++){printf("%pn", &arr[i]);}return 0;}


int arr[3][4];//三行四列的二维数组char arr1[3][4];

int arr[3][4] = { 1, 2, 3, 4, 5 };//三行四列的二维数组

int arr[3][4] = { { 1, 2 }, { 3, 4 }, 5 };//三行四列的二维数组

int arr[][4] = { { 1, 2 }, { 3, 4 }, 5 };//二维数组,即使你给它初始化了,行数可以省略,但是列数是不能省略的

#include<stdio.h>int main(){int arr[][4] = { { 1, 2 }, { 3, 4 }, 5 };//二维数组,即使你给它初始化了,行数可以省略,但是列数是不能省略的int i = 0;//行数int j = 0;//列数for (i = 0; i < 3; i++){for (j = 0; j < 4; j++){printf("%d ", arr[i][j]);}printf("n");}return 0;}

输出结果:


#include<stdio.h>int main(){int arr[][4] = { { 1, 2 }, { 3, 4 }, 5 };//二维数组,即使你给它初始化了,行数可以省略,但是列数是不能省略的int i = 0;//行数int j = 0;//列数for (i = 0; i < 3; i++){for (j = 0; j < 4; j++){printf("&arr[%d][%d] = %pn", i ,j,&arr[i][j]);}printf("n");}return 0;}

输出结果:



在内存中连续存放的用途:

#include<stdio.h>int main(){int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };int*p = arr;int i = 0;for (i = 0; i < 10; i++){printf("%d ", *p);p++;}return 0;}

输出结果:

#include<stdio.h>int main(){int arr[3][4] = { { 1, 2 }, { 3, 4 },{ 5 } };int*p = &arr[0][0];int i = 0;for (i = 0; i < 12; i++){printf("%d ", *p);p++;}return 0;}

输出结果:


#include<stdio.h>void bubble_sort(int arr[],int sz){int i = 0;//冒泡排序的趟数for (i = 0; i < sz - 1; i++){//一趟冒泡排序int j = 0;for (j = 0; j < sz - 1 - i; j++){if (arr[j]>arr[j + 1]){int tmp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = tmp;}}}}void print_arr(int arr[], int sz)//此处必须为arr[] err - arr{int i = 0;for (i = 0; i < sz - 1; i++){printf("%d ", arr[i]);}printf("n");}int main(){int arr[] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };int sz = sizeof(arr) / sizeof(arr[0]);//不可在函数内部//排序 - 排成升序//arr是数组//数组传参的时候,数组名会发生降级//数组名降级为数组首元素的地址//数组传参实际上穿的是数组首元素的地址print_arr(arr, sz);bubble_sort(arr,sz);//冒泡排序的方法print_arr(arr, sz);return 0;}

输出结果:

绝大多数情况下:数组名是首元素的地址。有两个例外:
sizeof(数组名) , 数组名是整个数组,计算的是整个数组的大小。
&数组名,数组名表示整个数组,去除的是整个数组的地址。

二维数组传参:

#include<stdio.h>void print_arr(int arr[3][3], int row, int col){int i = 0;int j = 0;for (i = 0; i < col; i++){for (j = 0; j < col; j++){printf("%d ",arr[i][j]);}printf("n");}}int main(){int arr[3][3] = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };print_arr(arr,3,3);return 0;}

输出结果:

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。