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

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

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

6.2K30

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语言------数组

    &arr[9]=0000004275FEF8C4 地址过于长,因为我们配置是x64环境 在64位环境中地址是64bit位,就比较长 为了观察方便,将配置环境该成x86环境,就是32位环境...:0 1 2 3 4 5 6 7 8 9 十六进制数字:0 1 2 3 4 5 6 7 8 9 10-a 11-b 12-c 13-d 14-e 15-f 十六进制中,逢十六进一,,,,,6c+4...个位上c+4等用于12+4=16,满16进一,1+6=7,所以6c+4=70 所以上述数组地址都只相隔4 1个int类型字节占4个字节 得出结论: 1.数组在内存中是连续存放 2.随着数组下标的增长...,列不能省略 int date[][5] = {{1,2},{3,4},{5,6}}; 二位数组使用 数组名是地址 c语言默认行和列默认从0开始 int arr[3][5] = {1,2,3,4,5... int main() { //char arr[] = "abc"; //a b c \0 //0 1 2 3对应下标,最右边结尾c所对应下标应该-1

    7610

    C语言数组

    C 语言支持数组数据结构,它可以存储一个固定大小相同类型元素顺序集合。数组是用来存储一系列数据,但它往往被认为是一系列相同类型变量。...数组特定元素可以通过索引访问。 所有的数组都是由连续内存位置组成。最低地址对应第一个元素,最高地址对应最后一个元素。 ?...声明数组C 中要声明一个数组,需要指定元素类型和元素数量,如下所示: type arrayName [ arraySize ]; 这叫做一维数组。...所有的数组都是以 0 作为它们第一个元素索引,也被称为基索引数组最后一个索引数组总大小减去 1。以下是上面所讨论数组图形表示: ?...访问数组元素 数组元素可以通过数组名称加索引进行访问。元素索引是放在方括号内,跟在数组名称后边。

    5.1K10

    C语言数组

    等待太久得来东西,多半已经不是当初自己想要样子了。 数组理解 1. 数组是⼀组相同类型元素集合。 2. 数组中存放是一个或者多个数据,但是数组元素个数不能为0。 3....数组中存放多个数据,它们类型是相同。 一维数组  一维数组创建并初始化  1. 创建一维数组同时,最好给数组初始化,否则数组内将存放任意值。 2....数组名实际上是数组首元素地址。  2. 但是有两点例外: sizeof(数组名),这里数组名表示整个数组,计算是整个数组大小。  ...&(数组名),这里数组名也表示整个数组,取出整个数组地址。...整型数组,是存放整型数组;字符数组,是存放字符数组;指针数组,就是一种存放指针数组 。 2. 可以利用数组指针实现二维数组功能。 3.

    3100

    C语言数组

    3.1 数组下标 C语言规定数组是有下标的,下标是从0开始,假设数组有n个元素,最后一个元素下标是n-1,下标就相当于数组元素编号,如下: int arr[10] = {1,2,3,4,5,6,7,8,9,10...}; 在C语言数组访问提供了一个操作符 [] ,这个操作符叫:下标引用操作符。...所以我们得出结论:数组在内存中是连续存放。 5. sizeof计算数组元素个数 在遍历数组时候,我们经常想知道数组元素个数,那C语言中有办法使用程序计算数组元素个数吗?...sizeof 中C语言是一个关键字,是可以计算类型或者变量大小,其实 sizeof 也可以计算数组大小。...C99中变长数组C99标准之前,C语言在创建数组时候,数大小指定只能使用常量、常量表达式,或者如果我们初始化数据的话,可以省略数组大小。

    8410

    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};

    15910

    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.

    5410

    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语言数组

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

    8310

    C语言数组——字符数组

    字符数组 字符数组顾名思义就是数组元素类型为字符型数组。特殊之处在于它是数组元素为字符数组。其定义一般形式和注意事项与之前讲解一般数组类似,只是其中类型说明符是char。...}; for (i = 0; i < SIZE; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 运行结果为“Hello...看看上面代码中定义arr数组,其数组长度为20,而初始化字符元素个数为12,初始化字符元素个数小于数组长度,编译器在编译过程中将后面没有初始化数组元素赋值为‘\0’,这也正是打印输出中含有空字符原因...='\0'; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 这时输出结果中就不含有任何空字符了,因为巧妙地使用了字符数组...= '\0'; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 在对一维字符数组进行定义和初始化过程中,可以不指定其长度。

    7.5K20

    C语言数组——字符数组

    C语言目录 C/C++学习资源(百度云盘链接) 计算机二级资料(过级专用) C语言学习路线(从入门到实战) 编写C语言程序7个步骤和编程机制 C语言基础-第一个C程序 C语言基础-简单程序分析...VS2019编写简单C程序示例 简单示例,VS2019调试C语言程序 C语言基础-基本算法 C语言基础-数据类型 C语言输入输出函数 C语言流程控制语句 C语言数组——一维数组...C语言数组——二维数组 前面两篇文章分别介绍了一维数组和二维数组,今天我们一起看看字符数组 字符数组 字符数组顾名思义就是数组元素类型为字符型数组。...特殊之处在于它是数组元素为字符数组。其定义一般形式和注意事项与之前讲解一般数组类似,只是其中类型说明符是char。...如果您觉得本篇文章对您有帮助,请转发给更多的人 【C语言中文社区】是一个C语言视频教程、学习笔记、电子书、计算机二级资料等专注于C语言编程学习者干货知识分享平台,精选深度文章,分享优秀干货类、技能类学习资源

    6.2K40

    c语言如何遍历数组,C语言数组遍历

    C语言数组遍历教程 C语言for循环遍历数组详解 语法 for (i = 0; i < count; i++) { // arr[i] } 说明 其中 count 是数组元素个数,此时,数组每一个元素是...C语言while循环遍历数组详解 语法 int i = 0; while(i < count) { // arr[i] i++; } 说明 其中 count 是数组元素个数,此时,数组每一个元素是...C语言do while循环遍历数组详解 语法 int i = 0; do { // arr[i] i++; }while(i < count); 说明 其中 count 是数组元素个数,此时,数组每一个元素是...案例 for循环数组遍历 我们可以通过 for 循环加索引形式遍历数组 #include int main(){ printf(“嗨客网(www.haicoder.net)\n\n”); //...C语言数组遍历总结 C 语言数组遍历,有三种方式,分别为:通过 for 循环遍历,通过 while 循环遍历与通过 do while 循环遍历方式。

    6.9K20

    C语言C语言数组和指针

    ---- 友情提醒:本文可能是全csdn最详细指针内容了,希望你能用心读下去 前言 接下来讲解部分是指针进阶,包含多种指针以及对应数组,这部分章节对我们来说很重要,也是c语言重点模块儿,重要性不言而喻...(c/c++会把常量字符串储存到单独一个内存区域中) 当这两个指针指向同一个常量字符串时,实际上就是指向同一块儿地址**(指针就是地址,地址就是指针)** 2.数组指针 2.1数组指针定义 1.数组指针嘛...,当二维数组数组名被当作参数传递时,我们可以把二维数组想象成多个一维数组集合,则每一个一维数组相当于这个二维数组每一个元素,这样来看二维数组名其实就是第一行一维数组地址,所以我们就可以用数组指针来接受这个参数...这个数组类型就是去掉数组名剩下部分,比如这个数组大小是5个int,数组元素类型是int 解释2: parr1是数组名,去掉数组名,剩下就是数组类型,比如这个数组大小是10个int*,数组元素类型是整形指针...回调函数不是由该函数实现方直接调用,而是在特定事件或条件发生时由另外一方调用,用于对该事件或条件进行响应。 我们直接大白话给他翻译成通俗易懂语言。怎么样就是回调函数呢?

    64.7K37

    关于Golang语言数组索引有趣现象

    [5 4 3 2 1 0] 下面就一步步地分析是什么情况 [number:value] 在go数组中代表是在索引未number处位置上值为value 如果索引值越界了就会重置。...index : 0, value : 5 5 _ _ _ 1 _ index : 4, value : 1 5 _ _ _ 1 0 index : 5, value : 0 因为上一个操作元素索引为...4 ([4:1])所以下一个操作元素索引自动加1 5 _ 3 _ 1 0 index : 2, value : 3 5 _ 3 2 1 0 index : 3, value : 2 因为上一个操作元素索引为...2 ([2:3])所以下一个操作元素索引自动加1 5 1 3 2 1 0 index : 1, value : 4 操作数组元素顺序是按照声明时顺序,顺序操作。...接着上面的分析 5 1 3 2 1 0 index : 1, value : 4 这时如果继续操作下一个元素根据规则 索引加1 也就是 要对index : 2 元素进行 value : 10操作

    826100

    关于Golang语言数组索引有趣现象

    [5 4 3 2 1 0] 下面就一步步地分析是什么情况 [number:value] 在go数组中代表是在索引未number处位置上值为value 如果索引值越界了就会重置。...index : 0, value : 5 5 _ _ _ 1 _ index : 4, value : 1 5 _ _ _ 1 0 index : 5, value : 0 因为上一个操作元素索引为...4 ([4:1])所以下一个操作元素索引自动加1 5 _ 3 _ 1 0 index : 2, value : 3 5 _ 3 2 1 0 index : 3, value : 2 因为上一个操作元素索引为...2 ([2:3])所以下一个操作元素索引自动加1 5 1 3 2 1 0 index : 1, value : 4 操作数组元素顺序是按照声明时顺序,顺序操作。...接着上面的分析 5 1 3 2 1 0 index : 1, value : 4 这时如果继续操作下一个元素根据规则 索引加1 也就是 要对index : 2 元素进行 value : 10操作

    82370

    C语言数组——一维数组

    所谓数组,是指将那些具有相同类型、数量有限若干个变量通过有序方法组织起来一种便于使用形式。数组属于一种构造类型,其中变量被称为数组元素。...一位数组 一位数组是最简单数组类型,它定义形式如下: 类型说明符 数组名[常量表达式] 类型说明符是数组中每个元素类型,常量表达式是数组元素个数 在使用一维数组时候需要留意以下两个要点 常量表达式值必须是正整数...数组元素引用,数组起始元素下标为0 下来我们通过一个简单示例了解一下数组 代码如下: #include #define N 9 int main(void) { int...arr,在引用数组元素时,采用"数组名[下标]"方式,将其中每一个元素视为一个普通变量来进行操作。...需要注意是,因为定义数组arr仅含有9个元素,所以在使用过程中,下标值不能超过8,否则就会出现下标越界错误,示例如下: 在使用数组时候要特别注意数组越界,不然很有可能为自己埋下一颗雷(bug

    2.9K10

    c语言数组介绍

    文章目录 一、一维数组创建和初始化 1.数组创建 2.数组初始化 3.一维数组使用 4.一维数组在内存中存储 二、二维数组创建和初始化 1.二维数组创建 2.二维数组创建 3.二维数组创建...}; int arr2[] = { 1,2,3,4 }; int arr3[5] = { 1,2,3,4,5 }; char arr4[3] = { 'a',98, 'c'...}; char arr5[] = { 'a','b','c' }; char arr6[] = "abcdef"; 数组在创建时候如果想不指定数组的确定大小就得初始化。...char arr1[] = "abc"; char arr2[3] = { 'a','b','c'}; 3.一维数组使用 对于数组使用我们之前介绍了一个操作符:[],下标引用操作符。...C语言本身是不做数组下标的越界检查,编译器也不一定报错,但是编译器不报错,并不意味着程序就是正确,所以程序员写代码时,最好自己做越界检查。

    2.3K50
    领券