首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言笔记(7)数组篇

一、初识数组 1.数组的概念 数组是由一系列类型相同的数据对象依次排列组合而成 组成数组的数据对象被称作数组的元素 重点: 依次排列 类型相同 2.声明数组 //格式: 元素类型 数组名[元素数量...]; //示例: char c[5]; int n[10]; long l[3]; float f[2]; double df[1]; 3.数组初始化 //格式如下: 元素类型 数组名[元素数量]...C语言编译器不会检查数组是否越界。...2.1 二维数组的概念 二维数组就是由多个一维数组组成的数组int score[5][10] 二维数组的每个元素都是一维数组 一维数组的每个元素表示的都是一个储存区 在定义一个二维数组的时候,需要提供两个整数...前一个整数表示一维数组的个数,后一个整数表示一维数组里的储存区个数 数据类型表示的是每个储存区的类型 int score[5][10] //定义了1个二维数组,一共分为了5个数组.每个一维数组中有10

17710
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C语言一维数组二维数组、字符数组【C语言学习笔记】

    一维数组,二维数组,字符数组,字符串常用函数。 1.数组:一组有序数据的集合。 同一数组中每个元素的数据类型(int long short double float char...)必须相同。...a是数组名称,表示数组首元素的内存地址,a是常量。 10表示数组中有10个元素,数组的第一个元素下标是从0开始。 会在内存中开辟连续的10个空间存放整型数值。...3.定义一个全0的数组 int a[10]={0}; 4.对数组中的元素赋值,省略定义数组时的元素个数。...a表示数组名称,表示首行元素的地址,a是常量。 数组有5行,5列,二维数组行、列的下标是从0开始的。 数组的每一个元素在内存中都是按行连续存放的。...int a[][4]={1,2,3,4,4,3,2,1,5,6}; 5.定义全0数组 int a[3][4]={0}; 字符数组 数组的每一个元素都是字符 字符串: 结束符:‘\0’ c语言规定用字符‘

    1.4K10

    C语言通过指针引用数组【C语言学习笔记】

    通过指针引用数组 数组元素的(指针)实际上就是数组元素的地址,引用数组元素的值可以有下标法,或指针法。...0的元素,也就是说指针变量p中存放的时数组a第0号元素的地址,p=0或p=&a[0]; 2.如果指针p进行p=p+1,(或p++)运算表示在同一个数组中指针变量p指向下一个元素。...3.如果指针p进行p=p-1,(或p--)运算表示在同一个数组中指针变量p指向上一个元素。 4.p+i和a+i的含义是相同的,表示数组元素a[i]的内存地址,为&a[i]。...注意:[]为变址运算符,a[i]的本质就是按照a+i计算处元素的内存地址后,再取出该地址内存单元的值。...例题:将数组中a中n个整数按照相反顺序存放到数组a中 #include int main(){ void fun(int a[],int n); int a[10]={

    71910

    【C语言笔记】关于数组与指针的总结

    参考:C语言中文网 前言 数组与指针有很密切的联系,常见的结合情况有以下三种: 数组指针 指针数组 二维数组指针 数组指针 数组指针:指向数组的指针。...如果一个指针p指向一个数组arr[]的开头,那么p+i为数组第i个元素的地址,即&arr[i],那么*(p+i)为数组第i个元素的值,即arr[i]。...b = 2, c = 3; //定义一个指针数组 int *arr[3] = {&a, &b, &c};//也可以不指定长度,直接写作 int *parr[] //定义一个指向指针数组的指针...指针数组还可以和字符串数组结合使用,请看下面的例子: #include int main(void) { char *str[3] = { "hello C"...return 0; } 运行结果为: hello C hello C++ hello Java 二维数组指针 二维数组指针:指向二维数组的指针。

    1.1K10

    【C语言笔记】数组与指针不等价

    前言 数组与指针是不等价的,如: 数组名不可以改变,而指向数组的指针是可以改变的。 字符串指针指向的字符串中的字符是不能改变的,而字符数组中的字符是可以改变的。...求数组长度时,借用数组名可求得数组长度,而借用指针却得不到数组长度。 区别一 数组名的指向不可以改变,而指向数组的指针是可以改变的。...,这是不对的,数组名只能指向数组的开头。...原因就是:这种方式定义的字符串保存在常量区,是不可修改的。 区别三 求数组长度时,借用数组名可求得数组长度,而借用指针却得不到数组长度。...以上就是指针与其指向的数组的三个典型的区别:(1)遍历数组时需要注意;(2)修改字符串中的字符时需要注意;(3)求数组长度时需要注意。

    79830

    【C语言笔记】数组a与&a有什么不同?

    可见,对于一个数组: int a[5] = {0,1,2,3,4}; a与&a的值是相同的。为什么呢?...a是数组名,是一个数据区的常量,对其取地址(&a)就可以得到数组存储区域的地址,同样,a本身也代表了数组存储区的首地址。所以,a与&a的值是一样的。...(ptr-1) = %d\n",*(a+1), *(ptr-1)); return 0; } 运行结果为: *(a+1) = 1, *(ptr-1) = 4 *(a+1) = 1,是因为a+1代表数组第二个元素的地址...,即&a[1],*(a+1)为取该地址上的值,即为1;*(ptr-1)=4,是因为ptr指向的是整个数组内存区域之后的内存,即数组最后一个元素之后的地址,ptr-1就是指向数组的最后一个元素,*(ptr...以上就是今天分享的关于数组的一个小知识点,如有错误欢迎指出! ----

    1.7K30

    c语言 数组存放规则,C语言数组详解

    在C语言中, 数组属于构造数据类型。一个数组可以分解为多个数组元素,这些数组元素可以是基本数据类型或是构造类型。...因此按数组元素的类型不同,数组又可分为数值数 组、字符数组、指针数组、结构数组等各种类别。 本章介绍数值数组和字符数组,其余的在以后各章陆续介绍。数组类型说明 在C语言中使用数组必须先进行类型说明。...二维数组 前面介绍的数组只有一个下标,称为一维数组, 其数组元素也称为单下标变量。在实际问题中有很多量是二维的或多维的, 因此C语言允许构造多维数组。...C语言允许用字符串的方式对数组作初始化赋值。...这是由于在C语言中规定,数组名就代表了该数组的首地址。 整个数组是以首地址开头的一块连续的内存单元。如有字符数组char c[10],在内存可表示如图4.2。

    6.3K30

    C语言:数组-学习笔记(万字笔记)——翻新版

    前言: 本篇文章将会介绍C语言中数组的相关知识, 1、 数组的概念 1.1 什么是数组 数组是一组相同类型元素的集合。...sizeof函数是 C 语言和 C++语言中的一个运算符,用于计算数据类型或变量占用的内存字节数。 不知道大家有没有对 %zd\n" 有所疑惑,为什么这里要使用%zd 呢?...}; 下标的作用:准确、快速地找到数组中特定位置的元素,从而对其进行操作和使用 辅助理解: 假设我们把 C 语言中的数组想象成一个书架。...所以,理解 C 语言中一维数组在内存中的连续存储方式,对于我们有效地使用数组、优化程序性能以及避免一些常见的错误(比如内存越界访问)都非常重要。...结语: 本篇文章到这里就结束了,该篇文章讲了C语言中数组的相关知识,希望能够对大家有所帮助,后面后讲解数组相关例题,敬请期待!!!

    13510

    【C语言系列】C语言数组

    二、数组的定义 格式: 类型 数组名[元素个数]; 举例:存储5个人的年龄 Int agrs[5]; //在内存中开辟4x5=20个字节的存储空间 可以在定义数组的同时对数组进行初始化: Int ages...Int x[]={1,2}; Char ca[5]={‘a’,‘A’,‘B’,‘C’,‘D’}; 数组名即代表数组的地址,数组的地址==数组名(ca)==数组的首元素的地址&ca[0] 在内存中,内存从大到小进行寻址...,为数组分配了存储空间后,数组的元素自然的从上往下排列存储,整个数组的地址为首元素的地址。...0; } Array数组与ages数组的地址一致,若以数组作为函数的参数,这种传递方式是传址调用,传递的是整个数组的地址,修改形参数组元素的值,就是修改实参的值。...使用场合:五子棋,俄罗斯方块等, 假设: char Y[3][2]={ {‘A’,‘B’}, {‘C,‘D’}, {‘E,‘F’} }; 内存情况: ?

    28.6K62

    C语言-数组

    数组介绍 C语言的数组是一个同类型数据的集合,主要用来存储一堆同类型的数据。 程序里怎么区分是数组?[ ] 这个括号是数组专用的符号. 定义数组、 访问数组数据都会用到。...访问数组成员的时候:下标是从0开始的。int data[10]; 下标 (0~9) 2. 数组只是支持在定义的时候进行整体赋值。 3. 数组定义的时候,[]里只能填常量。...数组在定义之后就无法更改大小。 4. 数组的空间是连续的—内存。 5. 数组的名称就是数组空间的首地址。 6. 数组初始化时,如果没有赋值,那么数组空间里的数据是未知的---局部变量。 7....数组定义语法与注意事项 1. 数组的名称是数组元素的首地址。(数组的名字就是地址) 2. 数组只能在初始化的时候进行整体赋值。比如: int a[100]={10,20,30}; 3....数组定义的时候(C89), 数组的下标里的大小只能填常量。

    4K10

    C语言数组

    // 代码 3 char arr3 [ 10 ]; float arr4 [ 1 ]; double arr5 [ 20 ]; 注: 数组创建,在 C99...在 C99 标准支持了变长数 组的概念,数组的大小可以使用变量指定,但是数组不能初始化。 1.2 数组的初始化、 数组的初始化是指,在创建数组的同时给数组的内容一些合理初始值(初始化)。...5 } ; char arr4 [ 3 ] = { 'a' , 98 , 'c' }; char arr5 [] = { 'a' , 'b' , 'c' }; char...char arr1 [] = "abc" ; //字符数组 char arr2 [ 3 ] = { 'a' , 'b' , 'c' }; 1.3 一维数组的使用 对于数组的使用我们之前介绍了一个操作符...C 语言本身是不做数组下标的越界检查,编译器也不一定报错,但是编译器不报错,并不意味着程序就 是正确的, 所以程序员写代码时,最好自己做越界的检查 #include int

    8810

    【c语言】数组

    从这里可以看出,首先数组中的元素,它们的类型是相同的,其次数组可以存放1个或者多个数据,但是数组的大小不能为0。 数组可以分为一维数组和多维数组,在多维数组当中,二维数组比较常用。...对于一维数组int arr[10]={1,2,3,4,5,6,7,8,9,10}: 为了能够使用下标操作数据,c语言提供了一种操作符:[],叫做下标引用操作符。...四、变长数组 在C99标准之前,数组创建时的元素个数只能是一个常量,这导致数组创建之后,如果过大则会浪费空间,过小又不够用。...而C99中加入了一个新的概念--变长数组,它允许创建数组时所设置的元素个数为一个变量。...不过,所谓“变长数组”并非真正意义上的“变长”,它在创建好之后大小仍然是不可变的。目前VS2022虽然支持大部分C99的语法,但是无法支持变长数组。

    10210

    C语言——数组

    →   int arr [3] ={1,2,3}  数组如果初始化了,可以不规定大小,数组会根据初始化的大小来确定大小 c,数组的类型 数组里的元素有分类型,数组也是有类型的,而数组算是一种自定义类型。...a,数组下标 C语言中,数组的下标是从0开始的,如果有n个元素,则第一个元素的下标为0,最后一个元素的下标为n-1 ,下面举例: 对于:            int arr [5] = {1,2,3,4,5...}; 数组元素:           1   2   3  4   5  对应下标:           0   1   2   3  4   C语言中 [ ] 是“下标引用操作符” ,...+) {          printf("%d",arr[i]); }  c,储存 这里主要讲下数组的元素在内存中储存的特点: 我们先用一下代码来依次打印出一维数组里元素的地址: 得到: 由上述打印出的地址...C99中的变长数组 一般来说,数组的大小指定只能使用常量,常量表达式,或直接初始化而省略大小: int arr1[10]; int arr2[3+5]; int arr3[] = {1,2,3};

    16610

    c语言_数组

    数组 1、数组的定义和使用 格式: 数据类型 数组名[元素个数] 元素个数,代表该数组有多少个相同数据类型的变量 下标 用来表示数组中的某一个元素 例如 int arr[10]; arr[1]代表数组的第二个元素...数组下标是从0开始的 到数组元素个数-1 数组下标越界:超出了数组元素个数的下标,如果操作越界数据会出现程序错误 1、乱码结果 2、报错 求出数组元素个数: int (size_t) unsigned...(数据类型)) 数组名+1(sizeof(数组名)) 练习:十只小猪称体重 定义一个数组 存储小猪体重 通过遍历找到最重的小猪 找到数组中数据最大值的下标 根据下标打印数据 练习: 找到小猪中第二重的...scores【10】【3】 求出每名学生的总成绩和平均成绩 求出班级的语文 数学 英语的平均成 语数外 【0】【0】 【0】【1】 【0】【2】 字符数组和字符串: 字符数组和字符串区别在于是否有字符串结束标志...中就是数字0 ​ printf("%s", arr); ​ //for (int i = 0; i < 10; i++) ​ //{ ​ // printf("%c", arr[i]); ​ //} ​

    4.5K20

    C语言——数组

    [ ] 中的常量值是⽤来指定数组的⼤⼩的,即数组元素个数, 不仅仅是常量值,也可以是常量表达式的形式,比如[3+5] 在 C99标准之前 ,C语⾔在创建数组的时候,数组⼤⼩的指定只能使⽤...也就是说,C语言 不 可以对数组的大小 作动态的定义 ,比如下面在两个定义方式是错误的 int n; scanf("%d",&n); int arr[n];//想要通过在程序中输入数组的大小 int...目前在VS2022上,没有⽀持C99中的变⻓数组,在搭配有gcc编译器的集成开发环境是支持的,比如DevC++,上面的代码就是通过DevC++实现的。...使用 下标 C语⾔规定数组是有下标的,并且下标是从0开始的,假设数组有n个元素,最后⼀个元素的下标是n-1,下标就相当于数组元素的编号。...它的特点是逢16进1(比如输出结果中7C--->80,就是C(12)+4=16进1.

    7210

    C语言------数组

    一.一维数组 数组也是有类型的,去掉数组的名字就是数组的类型; [  ]叫做下标引用操作符,我们利用他可以轻松访问任何一个元素,数组的下标是从0开始的,如果不注意,会造成越界访问;定义数组是,如果不指定数组的大小...,则数组的大小就由大括号内的元素的个数决定, %p是打印地址的,通过打印数组中每个元素的地址(以16进制的形式进行打印,而且开头的0不会省略)(%#x可以让打印的结果前面加上0x,x无论大写,小写都可以...),我们可以看出数组中的元素是如何排列的;显然,他们之间相差4个字节,那么我们也可以得出,一维数组在内存中是连续存在的 二.二维数组 创建时,行可以省略,但是列不能省略 二维数组也是线性排列的,第一行排列完成后排列下一行...; 三.C99引入变长数组 用变量指定数组大小,不是数组的长短是变化的;VS不支持变长数组 strlen求字符串长度,统计的是\0之前的字符的个数,不包括\0; 但是sizeof在计算数组所占内存的大小的时候...,不会关心\0; 四.实战演练-----数组元素移动------二分查找 1.多个字符从两端移动,向中间汇聚 2.数组元素的查找,用二分查找法 正常的方法进行遍历

    6210
    领券