首页 > 其他分享 >C语言_数组(1)

C语言_数组(1)

时间:2024-07-19 19:58:28浏览次数:17  
标签:初始化 数组 创建 代码 二位 C语言 一维

一、一维数组

1、数组的创建方式:

数组是有限个相同类型数据元素的集合。

type_t   arr_name   [const_n];
//type_t 是指数组的元素类型
//const_n 是一个常量表达式,用来指定数组的大小

创建例子:

注意:数组在创建时,[]里的必须是常量。但是如果编译器支持C99标准的话可以使用变量。

2、数组的初始化:

数组的初始化是指,在创建数组的同时给数组的内容一些合理初始值(初始化)。 看代码:
int arr1[10] = {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";

数组在创建时如果不指定数组的长度就要给数组初始化,数组根据初始化的值来确定数组大小。

数组如果不初始化默认值是0。

3、一维数组的使用

对于数组的使用我们介绍一个操作符: [] ,下标引用操作符。它其实就数组访问的操作符。 我 们来看代码:

数组通过下标来访问,下标是从0开始的。

4、一维数组的存储方式

我们来研究一下一维数组在内存中的存储方式,我们通过输出数组各元素地址的方式来研究。

代码如下:

%p输出地址,我们可以看到数组的每个元素地址都相差一个整形(4个字节),所以数组在内存当中是连续存放的。

注意:这里相差4个字节,是因为我的数组是整形类型的,如果定义别的数据类型,就会相差对应的大小。

二、二维数组

1、二位数组的创建

说完了一维数组,二维数组就是一维数组的扩展。

二位数组的创建:

arr【】【】第一个【】是行,第二个【】是宽。 

2、二维数组的初始化

二位数组的行可以省略 ,但宽不能省略。

二位数组也可以单独给哪一行赋值。

代码如下:

3、二位数组的使用

二位数组的使用也是通过下标的方式访问

4、二位数组的存储方式

我们还是通过看地址的方式来研究

根据上图我们发现二维数组也是一块连续的空间。 

数组(1)gitee代码链接:马飞扬/C语言代码库 - 码云 - 开源中国 (gitee.com)

标签:初始化,数组,创建,代码,二位,C语言,一维
From: https://blog.csdn.net/mfy12138/article/details/140557402

相关文章

  • 顺序表实现队列(c语言)
    队列概念篇图示代码篇1.队列的声明2.队列的创建3.队列的销毁4.队列扩容5.入列6.出列6.队首元素7.队列的元素个数完整代码运行结果建议你在看这篇文章先看一下顺序表知识。我在这里通过顺序表的写法实现先进先出的特征来实现队列。当然顺序表也可以实现栈,感......
  • 线性表——链表(c语言)
    链表概念篇示意图1.单向链表2.双向链表3.循环链表4.链表的元素插入5.链表的元素删除代码篇1.链表的定义2.链表的创建3.链表的销毁4.链表的元素插入5.链表的元素删除6.链表的元素查找7.链表下标对应的结点8.链表元素的修改9.链表的打印10.完整代码代码运行效果概......
  • 【c语言】日日练-通讯录
    通讯录题目解析(实现过程+要点)代码test.c(测试功能)contact.c(通讯录相关的实现)contact.h(通讯录相关的声明)题目实现一个通讯录,人的信息包括(姓名、年龄、性别、电话、地址)实现功能:1、存放100个人的信息2、增加联系人3、删除指定联系人4、查找联系人5、修改联系......
  • 合并排序数组
    合并排序数组(蓝桥杯题库)题目描述给定排序数组A和B,实现一个算法将B按排序顺序合并到A中。介绍如下:数组A和B的均为排序数组,数字按从小到大排列。数组A的的长度为 ......
  • 34.拷贝数组
    定义一个方法:copyOfRange(int[]arr,intx,inty)将数组arr中从索引x开始(包含x)到索引y结束(不包含y)中的元素,复制到新数组中,并将新数组返回例:原始数组arr={1,2,3,4,5,6,7,8,9},新数组newArr={4,5,6,7}publicstaticvoidmain(String[]args){//1.静态初始化定......
  • C语言运算符
    1.算术运算符+加法-减法*乘法/除法%取余 计算时,数据类型不一样的不能直接运算,需要转换成一样的才能运算,有两种转换方式。1.1隐式转换把一个取值范围小的,转换为取值范围大的,隐式转换是计算机自己就可以完成的,不会产生错误的。数据类型从大的到小的顺序为:double>float>lon......
  • C语言函数详解
    函数的概念不同于数学上的函数,在C语言中,函数(function)就是一个完成某项特定任务的一段代码,所以函数也叫子程序。函数的分类库函数为了提高写代码的效率,C语言的国际标准ANSIC规定了一些常用的函数的标准,被称为标准库。不同的编译器厂商根据ANSI提供的标准就给出了一系列函数......
  • C语言基础(二)
    数据类型    数据类型介绍:            整型类型来描述整数,字符类型来描述字符,浮点型类型来描述小数;    字符型:char//character[signed]char//有符号的unsignedchar//⽆符号的    整型://短整型short[int][signed]s......
  • C语言基础(四)
    printf库函数基本用法:printf()的作⽤是将参数⽂本输出到屏幕。它名字⾥⾯的f代表format(格式化),表⽰可以定制输出⽂本的格式。#include<stdio.h>intmain(){printf("Hello,world");return0;}printf()不会在行尾自动添加换行符,运行结束后,光标就停留在输......
  • C语言基础(三)
    算数操作符:+、-、*、\、%    C语言中为了方便运算,提供了一系列操作符(运算符),其中有一组操作符叫:算术操作符。分别是:+-*/%,这些操作符都是双目操作符。*运算符    用来完成乘法运算。/运算符    用来完成除法运算。    除号的两端如......