当前位置: 首页 > news >正文

C++ 数组

数组是具有一定顺序关系的若干对象的集合体,组成数组的对象称为该数组的元素。 数组元素用数组名与带方括号的下标表示,同一数组的各个元素具有相同的类型。数组可以由除void型以外的任何一种类型构成,构成数组的类型和数组之间的关系,可以类比为数学上数与向量或矩阵的关系。

每个元素有n个下标的数组称为n维数组。如果用array来命名一个数组,且其下标为从0到N的整数,则数组各元素为array[0],array[1],…,array[N]。这样一个数组可以顺序存储N+1个数据,因此N+1就是数组array的大小,数组的下标下界为0,数组的下标上界为N。

1.数组的声明与使用

(1)数组的声明

数组属于自定义数据类型,因此在使用之前首先要进行类型声明。声明一个数组类型,应该包括以下几个方面:

①确定数组的名称
②确定数组元素的类型
③确定数组的结构(包括数组维数,每一维的大小等)

数组类型声明的一般形式为:

数据类型 标识符[常量表达式1][常量表达式2]...;

数组中元素的类型是由“数据类型”给出,这个数据类型,可以是整型、浮点型等基本类型,也可以是结构体、类等用户自定义类型。数组的名称由“标识符”指定。

“常量表达式1”、“常量表达式2”、…称为数组的界,必须是在编译时就可求出的常量表达式,其值必须为正整数。数组的下标用来限定数组的元素个数、排列次序和每一个元素在数组中的位置。一个数组可以有多个下标,有n个下标的数组称为n维数组,数组元素的下标个数称为数组的维数。声明数组时,每一个下标表达式表示该维的下标个数(注意:不是下标上界)。数组元素个数是各下标表达式的乘积。例如:

int b[10];

表示b为int型数组,有10个元素:b[0]~b[9],可以用于存放10个元素的整数序列。

int a[5][3];

表示a为int型二维数组,其中第一维有5个下标(0~4),第二维有3个下标(0~2),数组元素的个数为15,可以用于存放5行3列的整型数据表格。值得注意的是数组下标的起始值为0。对于上面声明的数组a,第一个元素是a[0][0],最后一个元素是a[4][2]。也就是说每一维的下标都是从0开始。

(2)数组的使用

使用数组时,只能分别对数组的各个元素进行操作。数组的元素是由下标来区分的。对于一个已经声明过的数组,其元素的使用形式为:

数组名[下标表达式1][下标表达式2]...

其中下标表达式个数取决于数组的维数,N维数组就有N个下标表达式。

数组中的每一个元素都相当于一个相应类型的变量,凡是允许使用该类型变量的地方,都可以使用数组元素。可以像使用一个整型变量一样使用整型数组的每一个元素。同样,每一个类类型的数组也可以和一个该类的普通对象一样使用。在使用过程中注意以下两点:

(1)数组元素的下标表达式可以是任意合法的算术表达式,其结果必须为整数。
(2)数组元素的下标值不得超过声明时所确定的上下界,否则运算时数组越界错误。

【例】数组的声明与使用

#include<iostream>
using namespace std;int main()
{int a[10], b[10];for (int i = 0; i < 10; i++){a[i] = i * 2 - 1;b[10 - i - 1] = a[i];}for (int i = 0; i < 10; i++){cout << "a[" << i << "]=" << a[i] << endl;cout << "b[" << i << "]=" << b[i] << endl;}return 0;
}

运行结果:
在这里插入图片描述
结果分析:
程序中,定义了两个有10个元素的一维数组a和b,使用for循环对它们赋值,在引用b元素时采用了算术表达式作为下标。程序运行之后将-1,1,3,…,17分别赋给数组元素a[0],a[1],…,a[9],数组b中元素的值刚好是数组a中的逆序排列。

如果把两个循环语句for(int i=0;i<10;i++)改写为for(int i=1;i<=10;i++),在编译和连接过程中都不会出错,但最后运行时不仅不会得到正确结果,而且有可能产生意想不到的错误,这就是一个典型的数组越界错误。如下:

#include<iostream>
using namespace std;int main()
{int a[10], b[10];for (int i = 1; i <= 10; i++){a[i] =  i * 2 - 1; ;b[10 - i - 1] = a[i];}for (int i = 1; i <= 10; i++){cout << "a[" << i << "]=" << a[i] << endl;cout << "b[" << i << "]=" << b[i] << endl;}return 0;
}

运行结果:
在这里插入图片描述

2.数组的存储与初始化

(1)数组的存储

**数组元素在内存中是顺序、连续存储的。**数组元素在内存中占据一组连续的存储单位,逻辑上相邻的元素在物理地址上也是相邻的。一维数组是简单地按照下标的顺序连续存储的。多维数组的元素也是顺序、连续存储的,其存储顺序的约定非常重要。

元素的存储顺序问题关系到对数组做整体处理时,以什么样的顺序对数组元素进行操作。C++中很多操作都与数组元素的存储顺序相关,如数组初始化、函数间的数据传递等。

①一个一维数组可以看作是数学上的一个列向量,各元素是按下标从小到大的顺序连续存放在计算机内存单元中。例如,数组声明语句:

int arr[5];

声明了一个有5个元素的一维int型数组,可以看作是列向量[arr[0],arr[1],arr[2],arr[3],arr[4]],元素在内存中的存放顺序如下图所示:
在这里插入图片描述

②一个二维数组可以看作数学中的一个矩阵,第一个下标称为行标,第二个下标称为列标。例如,数组声明语句:

int m[2][3];

声明了一个数组,相当于一个2行3列的矩阵:
在这里插入图片描述
但在C++中,数组元素每一维的下标都是从0开始的,因此在程序中,矩阵M就被表示为:
在这里插入图片描述
其中,元素m[1][0],行标为1,列标为0,表示矩阵第2行第1个元素。二维数组在内存中是按行存放的,即先放第1行,再放第2行…每行中的元素是按列下标从小到大的顺序存放,这样的存储方式也称为优先存储。二维数组m在内存中的存放顺序如下图所示:
在这里插入图片描述
【注意】
C++中二维数组被当作一维数组的数组。例如int m[2][3]所定义的m,可以看作是这样一个数组,它的大小是2,每一个元素都是一个大小为3、类型为int的数组。由于数组的每个元素都要存放在连续空间中,因此二维数组自然会按行优先的顺序存储。

③多维数组也是采取类似的方式顺序存放。

(2)数组的初始化

数组的初始化就是在声明数组时给部分或全部元素赋初值。对于基本类型的数组,初始化过程就是给数组元素赋值;对于对象数组,每个元素都是某个类的一个对象,初始化就是调用该对象的构造函数。

声明数组时给出数组元素的初值,例如:

#include<iostream>
using namespace std;int main()
{int a[10] = { 1,2,3,4,5,6,7,8,9,10 };for (int i = 0; i < 10; i++){cout << "a[" << i << "]=" << a[i] << endl;}return 0;
}

运行结果:
在这里插入图片描述
表示声明了一个具有10个元素的int型数组,数组元素a[0],a[1],…,a[10]的值分别为1,2,3,4,5,6,7,8,9,10。声明数组时如果列出全部元素的初值,可以不用说明数组元素的个数,下面语句和int a[10] = { 1,2,3,4,5,6,7,8,9,10 };语句完全等价:

int a[] = { 1,2,3,4,5,6,7,8,9,10 };

当然,也可以只对数组元素中的部分元素进行初始化,比如声明一个有5个元素的浮点型数组,给前3个元素分别赋值1.0,2.0,3.0,可以写为:

int main()
{float fa[5] = { 1.0,2.0,3.0 };int a[10] = { 1,2,3,4,5,6,7,8,9,10 };for (int i = 0; i < 5; i++){cout << "a[" << i << "]=" << fa[i] << endl;}return 0;
}

运行结果:
在这里插入图片描述
这时数组元素的个数必须明确指出,对于后面没有赋值的两个元素,也不用做任何说明。初始化只能针对所有元素或者从起始地址开始的前若干元素,而不能间隔赋初值。

【注意】
当指定的初值个数小于数组大小时,剩下的数组元素会被赋予0值。若定义数组时没有指定任何一个元素的初值,对于静态生存期的数组,每个元素仍然会被赋值为0;但对于动态生存期的数组,每个元素的初值都是不确定的。例如:
①静态生存期的数组

#include<iostream>
using namespace std;int main()
{static int a[10]for (int i = 0; i < 10; i++){cout << "a[" << i << "]=" << a[i]<<" ";}return 0;
}

运行结果:
在这里插入图片描述
②动态生存期的数组

#include<iostream>
using namespace std;int main()
{int a[10];for (int i = 0; i < 10; i++){cout << "a[" << i << "]=" << a[i] << ",";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述
多维数组的初始化也遵守同样的规则。此外,如果给出全部元素的初值,第一维的下标个数可以不用显式说明,例如:

int a[2][3]={1,0,0,0,1,0};

等价于:

int a[][3]={1,0,0,0,1,0};

多维数组可以按第一维的下标进行分组,使用花括号将每一组的数据括起来。对于二维数组,可以分行用花括号括起来。下面的写法与上面的语句完全等效:

int a[2][3]={{1,0,0},{0,1,0}};

采用括号分组写法,容易识别,易于理解。

此外,数组也可以被声明为常量,例如:

const float fa[5]={1.0,2.0,3.0};

它表明fa数组中每个元素都被当作常量对待,也就是说它们的值在初始化后皆不可以改变。声明为常量的数组,必须给定初值。

相关文章:

C++ 数组

数组是具有一定顺序关系的若干对象的集合体&#xff0c;组成数组的对象称为该数组的元素。 数组元素用数组名与带方括号的下标表示&#xff0c;同一数组的各个元素具有相同的类型。数组可以由除void型以外的任何一种类型构成&#xff0c;构成数组的类型和数组之间的关系&#x…...

Android LinearLayout dynamic add child ImageView,Glide load,kotlin

Android LinearLayout dynamic add child ImageView&#xff0c;Glide load&#xff0c;kotlin images.xml <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"andro…...

HTML 是什么?它的全称是什么?

聚沙成塔每天进步一点点 专栏简介HTML是什么&#xff1f;HTML的全称是什么&#xff1f;写在最后 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅&#xff01;这个专栏是为那些对We…...

ATF(TF-A)安全通告

目录计划如下&#xff0c;相关内容补充中&#xff0c;待完成后进行超链接&#xff0c;敬请期待&#xff0c;欢迎关注 1、Advisory TFV-1 (CVE-2016-10319) 2、Advisory TFV-2 (CVE-2017-7564) 3、Advisory TFV-3 (CVE-2017-7563) 4、Advisory TFV-4 (CVE-2017-9607) 5、Adviso…...

LVS—DR集群的搭建

目录 lvs-dr模式工作原理&#xff1a; 搭建结构&#xff1a; 1、RS&#xff1a; 1&#xff09;两台RS准备好httpd环境和测试文件 2&#xff09;添加虚拟IP&#xff08;vip&#xff09;、添加访问本地vip的静态路由 并抑制ARP 2、DS&#xff1a; 1&#xff09;安装ipvasadm…...

如何理解容量测试?如何做容量测试?

1、如何理解容量测试&#xff1f; 容量测试&#xff0c;是性能测试里的一部分&#xff0c;它的目的是测量系统的最大容量&#xff0c;为系统扩容、性能优化提供参考&#xff0c;节省成本投入&#xff0c;提高资源利用率。就是运用各种方法和工具在这种复杂的情况下去不断验证容…...

文件上传漏洞(webshell)

一、防护 1、防护 1、判断文件后缀&#xff0c;为图片的话才让上传成功。 2、解析文件内容&#xff08;文件幻数&#xff09;判断文件头和文件尾部是否一致 幻数 常见的 3、隐藏按钮&#xff08;带上code唯一值&#xff09; 4、二次渲染&#xff08;类似拿着你的图片&#xff…...

.net几行代码音乐API各排行榜 热搜 入库

对比了几家大厂的音乐API的接口 这家相对规范些 现在开始从零开始 net6敏捷开发对接 入库吧 关键技术工具和思维 1 json 生成类 2 分析类 规划表设计3 sqlsuger codefirst 生成表 4 封装get post 连接5 类映射automapper6 sqlsuger 插入数据 1 json 生成类 宇宙 第 一的…...

使用gpt对对话数据进行扩增,对话数据扩增,数据增强

我们知道一个问题可以使用很多方式问&#xff0c;但都可以使用完全一样的回答&#xff0c;基于这个思路&#xff0c;我们可以很快的扩增我们的数据集。思路就是使用chatgpt或者gpt4生成类似问题&#xff0c;如下&#xff1a; 然后我们可以工程化这个过程&#xff0c;从而快速扩…...

算法练习工程1.2

题目要求&#xff1a; * 问题标题&#xff1a;删除有序数组中的重复项&#xff1a; * 题意说明&#xff1a; * 给你一个 升序排列 的数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使每个元素 只出现一次 &#xff0c;返回删除后数组的新长度。 * …...

数字IC流片经历有多重要?怎样才能有流片机会?

都说拥有流片经验可以显示你在实际项目中的实践能力和对整个设计流程的了解程度&#xff0c;流片经历的重要性不言而喻。 什么是芯片流片 像流水线一样通过一系列工艺步骤制造芯片&#xff0c;这就是流片。在芯片制造过程中一般有两段时间可以叫作流片。 流片&#xff1a;英…...

fontfaceobserver 第三方字体加载优化方案

fontfaceobserver 第三方字体加载优化方案 1. github地址 https://github.com/bramstein/fontfaceobserver 2. 基础使用方法 const font new FontFaceObserver(My Family, {weight: 400 });font.load().then(function () {console.log(Font is available); }, function ()…...

laravel安装composer依赖

一.问题描述 拉取的新项目没有依赖 项目根目录没有vendor目录 报错 二.安装composer,拉取依赖 1.如果没有composer先去下载 官网地址:Packagist / Composer 中国全量镜像 我的博客安装composer:composer最新版本安装_荒-漠的博客-CSDN博客 2.进入项目根目录cmd或者在项目中…...

问题聚集度Hive SQL

问题聚集度&#xff1a;最小的分母占比&#xff0c;贡献最多的分子占比&#xff0c;即小规模贡献大问题。 selectcity_name,user_id,rf_type,deal_ord_cnt,sale_amt,rf_ord_cnt,rf_amt,rf_ra,rf_amt_ra,rf_all,ord_cnt_all,rf_gx,ord_cnt_gx,del_gx,row_number() over(partiti…...

Windows11右键菜单

刚开始使用Windows11时&#xff0c;新的右键菜单用起来很不习惯。 记录一下修改和恢复Windows11的右键菜单的方法。 1.Win11切换到旧版右键菜单&#xff1a; 方法&#xff1a;WinR打开CMD&#xff0c;运行下面的命令行 添加注册列表重启Windows资源管理器 reg add "HKC…...

篇十四:观察者模式:对象间的通知与更新

篇十四&#xff1a;“观察者模式&#xff1a;对象间的通知与更新” 设计模式是软件开发中的重要知识&#xff0c;观察者模式&#xff08;Observer Pattern&#xff09;是一种行为型设计模式&#xff0c;用于在对象间建立一种一对多的依赖关系&#xff0c;当一个对象的状态发生…...

Hadoop知识点总结

1. MapReduce中Shuffle的执行流程是什么样的&#xff1f; - 阶段&#xff1a;Map端Shuffle、Reduce端Shuffle - 功能&#xff1a;分区、排序、分组 Map端Shuffle 分区(Partition)&#xff1a;在这个阶段&#xff0c;Map任务会调用分区器&#xff0c;根据Key的Hash值取模&a…...

相关搜索量激增10000%!“芭比周边”产品火爆亚马逊!

据外媒报道&#xff0c;芭比娃娃是今年夏天最热的话题。今年7月份&#xff0c;“芭比娃娃”是亚马逊上搜索最多的词。第二季度&#xff0c;Shopify上的芭比娃娃销量激增了56%。知名玩具制造商美泰&#xff08;Mattel&#xff09;预计&#xff0c;受电影的推动&#xff0c;在未来…...

C高级第四讲

1、思维导图 2、写一个shell函数&#xff0c;获取用户的uid和gid并使用变量接收 #!/bin/bash function get_id() {uidid -u ubuntugidid -g ubuntu } get_id echo "uid:$uid" echo "gid:$gid"运行结果 3、排序 冒泡排序 /* ------------------------…...

Idea小操作

Idea操作 idea提取内容构成一个方法 idea提取内容构成一个方法...

定制你的专属探针:PEG-锰基纳米材料,为精准科研而生

在纳米生物医学研究的前沿&#xff0c;标准化的材料往往难以完全契合你的实验设想。你是否正在为TME响应成像、MRI造影增强、化学动力学Treatment 或药物递送系统的构建而寻找一种可调控、生物相容性良好的纳米平台&#xff1f;现在&#xff0c;你可以完全掌控参数——PEG-锰基…...

使用 Taotoken 后模型 API 响应延迟与稳定性效果实测观察

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 使用 Taotoken 后模型 API 响应延迟与稳定性效果实测观察 作为一名需要频繁调用大模型 API 的开发者&#xff0c;模型服务的响应速…...

基于RK3568J核心板的隔离网闸设计:硬件选型、系统架构与工程实践

1. 项目概述&#xff1a;当嵌入式核心板遇上网络安全“守门员”最近几年&#xff0c;“科技与狠活”这个词火遍全网&#xff0c;让大家对各种产品的成分和安全性都多了一份审视。其实&#xff0c;除了我们吃进嘴里的东西&#xff0c;另一个看不见摸不着却至关重要的领域——网络…...

FAST开发方法在系统分析中四个阶段

在系统分析师考试中,被频繁考查的FAST(Framework for the Application of Systems Thinking)方法,是一个聚焦于系统分析阶段的框架。 它的核心是将复杂的分析工作拆解为四个环环相扣的阶段:初始研究、问题分析、需求分析和决策分析。 📊 四个阶段速览 阶段 核心任务 1…...

手把手教你用TI TICS Pro配置LMX2594时钟芯片(附寄存器导出与SPI写入指南)

手把手教你用TI TICS Pro配置LMX2594时钟芯片&#xff08;附寄存器导出与SPI写入指南&#xff09; 在高速数字系统设计中&#xff0c;时钟信号的稳定性和精确度往往决定着整个系统的性能上限。作为射频与通信领域的工程师&#xff0c;我深刻体会过时钟配置失误带来的调试噩梦—…...

CircuitPython实战:用传感器数据驱动NeoPixel灯光效果

1. 项目概述如果你刚拿到一块像Adafruit Circuit Playground Express这样的开发板&#xff0c;看着上面一圈彩色的NeoPixel LED和一堆传感器&#xff0c;可能会有点无从下手。别担心&#xff0c;这几乎是每个嵌入式开发者的必经之路。这块板子集成了光传感器、温度传感器、加速…...

微软UFO项目:基于视觉大模型的GUI自动化智能体实战解析

1. 项目概述&#xff1a;当“全能”AI助手遇见复杂任务编排 最近在AI应用开发圈里&#xff0c;一个来自微软研究院的项目“UFO”引起了我的注意。这名字听起来挺科幻&#xff0c;全称是“UI-Focused Agent”&#xff0c;直译过来是“专注于用户界面的智能体”。但别被这个直白的…...

KISS原则在大模型时代的生死线:DeepSeek工程化落地中被忽略的4类隐性复杂度(附NASA级简洁度评分表)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;KISS原则在大模型时代的生死线&#xff1a;从哲学信条到工程铁律 为何越“聪明”的系统越需要极简设计 当大模型参数突破千亿、推理链路横跨数十个微服务、提示工程嵌套七层模板时&#xff0c;KISS&am…...

本地包管理器指南:实现开发环境隔离与依赖管理的工程实践

1. 项目概述&#xff1a;一个为开发者而生的本地包管理器指南如果你是一名开发者&#xff0c;尤其是经常在本地环境折腾各种工具、依赖和项目配置的开发者&#xff0c;那么“包管理器”这个词对你来说一定不陌生。无论是 Node.js 的 npm/yarn/pnpm&#xff0c;Python 的 pip/co…...

超长上下文时代来临:百万Token窗口实测,我的工作流彻底变了

前言&#xff1a;一个让我彻底改变工作方式的实验 2026年初&#xff0c;我做了一件以前根本不敢想的事&#xff1a;把一份长达800页的技术规范文档&#xff0c;直接塞进了一个大模型的上下文窗口&#xff0c;然后让它帮我找出其中所有与安全性相关的条款&#xff0c;并逐条解释…...