CH05_数组


概述

定义:一组相同类型的数据的集合。

描述:

1.数组中的每个元素都是相同的数据类型

2.数组是由连续的内存位置组成的。

3.数组索引是从0开始

一维数组

语法:

1.数据类型 数组名[长度];

2.数据类型 数组名[长度]={值1,值2,值3...};

3.数据类型 数组名[]={值1,值2,值3...};

示例:

#include <iostream>
using namespace std; int main() { //方式1
int nums1[5];
nums1[0] = 23;
nums1[1] = 17;
nums1[2] = 35; //方式2
int nums2[5] = { 12,35,100 }; //方式3
int nums3[]= { 12,35,100 }; //访问单个元素
cout << nums2[4] << endl; //遍历所有元素
int length = sizeof(nums2) / sizeof(nums2[0]);
for (int i = 0; i < length; i++) {
cout << nums2[i] << endl;
} //查看内存地址
cout << "数组首地址为:" << (int)nums2 << endl;
cout << "数组中第一个元素地址为:" << (int)&nums2[0] << endl;
cout << "数组中第二个元素地址为:" << (int)&nums2[1] << endl; system("pause");
return 0;
}

二维数组

语法:

数据类型 数组名[行数][列数];

数据类型 数组名[行数][列数]={{值1,值2},{值3,值4}};

数据类型 数组名[行数][列数]={值1,值2,值3,值4};

数据类型 数组名[ ][列数]={值1,值2,值3,值4};

示例:

#include <iostream>
using namespace std; int main() { //方式1.数据类型 数组名[行数][列数];
int arr1[2][3];
arr1[0][0] = 11;
arr1[0][1] = 12;
arr1[0][2] = 13;
arr1[1][0] = 14;
arr1[1][1] = 15;
arr1[1][2] = 16; //外层控制行数
for (int i = 0; i < 2; i++) {
//内层控制列数
for (int j = 0; j < 3; j++) {
cout << arr1[i][j] <<"\t";
}
cout << endl;
} cout << "-------------------" << endl; //方式2.数据类型 数组名[行数][列数] = { {值1,值2},{值3,值4} };
int arr2[2][3] =
{
{12,25,33},
{13,26,27}
}; //外层控制行数
for (int i = 0; i < 2; i++) {
//内层控制列数
for (int j = 0; j < 3; j++) {
cout << arr2[i][j]<<"\t";
}
cout << endl;
}
cout << "-------------------" << endl; //方式3.数据类型 数组名[行数][列数] = { 值1,值2,值3,值4 };
int arr3[2][3] = {1,2,3,4,5,6};//输入数值数量超出范围,则会编译不通过 //外层控制行数
for (int i = 0; i < 2; i++) {
//内层控制列数
for (int j = 0; j < 3; j++) {
cout << arr3[i][j] << "\t";
}
cout << endl;
}
cout << "-------------------" << endl; //方式4.数据类型 数组名[][列数] = { 值1,值2,值3,值4 };
int arr4[][3] = { 1,2,3,4,5,6,7,8 };//自动计算行数 //数组行数:(sizeof(a) / sizeof(int)) / (sizeof(a[0]) / sizeof(int))
//数组列数:(sizeof(a[0]) / sizeof(int))
int row = (sizeof(arr4) / sizeof(int)) / (sizeof(arr4[0]) / sizeof(int));
//外层控制行数
for (int i = 0; i < row; i++) {
//内层控制列数
for (int j = 0; j < 3; j++) {
cout << arr4[i][j] << "\t";
}
cout << endl;
}
cout << "-------------------" << endl; //获取二维数组内存地址
cout << "数组首地址:" << (int)arr4 << endl;
cout << "数组第一行第一列:" << (int)&arr4[0][0] << endl;
cout << "数组第一行第二列:" << (int)&arr4[0][1] << endl;
cout << "数组第二行第一列:" << (int)&arr4[1][0] << endl; system("pause");
return 0;
}

CH05_数组的更多相关文章

  1. javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈

    Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...

  2. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  3. 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)

    建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...

  4. 了解PHP中的Array数组和foreach

    1. 了解数组 PHP 中的数组实际上是一个有序映射.映射是一种把 values 关联到 keys 的类型.详细的解释可参见:PHP.net中的Array数组    . 2.例子:一般的数组 这里,我 ...

  5. JavaScript权威指南 - 数组

    JavaScript数组是一种特殊类型的对象. JavaScript数组元素可以为任意类型,最大容纳232-1个元素. JavaScript数组是动态的,有新元素添加时,自动更新length属性. J ...

  6. JavaScript常见的五种数组去重的方式

    ▓▓▓▓▓▓ 大致介绍 JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结 先来建立一个数组 var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN ...

  7. js:给定两个数组,如何判断他们的相对应下标的元素类型是一样的

    题目: 给Array对象原型上添加一个sameStructureAs方法,该方法接收一个任意类型的参数,要求返回当前数组与传入参数数组(假定是)相对应下标的元素类型是否一致. 假设已经写好了Array ...

  8. javascript数组查重方法总结

    文章参考地址:http://blog.csdn.net/chengxuyuan20100425/article/details/8497277 题目 对下列数组去重: var arr = ['aa', ...

  9. 掌握javascript中的最基础数据结构-----数组

    这是一篇<数据结构与算法javascript描述>的读书笔记.主要梳理了关于数组的知识.部分内容及源码来自原作. 书中第一章介绍了如何配置javascript运行环境:javascript ...

  10. 小兔JS教程(四)-- 彻底攻略JS数组

    在开始本章之前,先给出上一节的答案,参考答案地址: http://www.xiaotublog.com/demo.html?path=homework/03/index2 1.JS数组的三大特性 在J ...

随机推荐

  1. Nginx 静态站点配置不对导致301跳转的坑

    背景 是这样的,我们前端服务器统一的入口是 kong网关 ,我们还有一个Nginx静态资源站点:static.mysite.com,根配置如下: location / { root /home/web ...

  2. Mybatis、Mybatis Generator、Mybatis-Plus、Mybatis Plus Generator

    1.介绍 Mybatis Mybatis 是操作数据库的框架:提供一种Mapper类,支持用Java代码对数据库进行增删改查. 缺点:需要先在xml中写好SQL语句: Mybatis Generato ...

  3. 认真学习CSS3-问题收集-101号-莫名其妙的row行高

    其他人都有事情,有些事情只好自己上阵,自己做,最踏实! 做了两个基本一样的页面,都是采用bootsrap+jquey+js的技术,业务内容就是简单的查询,加上一些简单的效果,没有啥特别的内容. 由于历 ...

  4. AGC044C Strange Dance

    在2020年A卷省选day2t2有类似操作trie的技巧. 题目链接 显然是建一棵三叉trie树,代表0/1/2 对这棵trie树,我们需要支持子树交换和全局加1 考虑第一个操作怎么做?直接打个懒标记 ...

  5. ZYNQ:Linux添加I2C-RTC驱动

    硬件情况 使用的是DS1338这款RTC时钟芯片,I2C总线对应到PS端的I2C1. 配置 内核 添加有关的驱动: 因为DS1338用的驱动与DS13307相似,一找发现是同一个配置. CONFIG_ ...

  6. 数据结构—包(Bag)

    数据结构中的包,其实是对现实中的包的一种抽象. 想像一下现实中的包,比如书包,它能做什么?有哪些功能?首先它用来装东西,里面的东西可以随便放,没有规律,没有顺序,当然,可以放多个相同的东西.其次,东西 ...

  7. SpringBoot集成ShardingSphere分表中间件

    ShardingSphere简介 ShardingSphere 由 JDBC.Proxy 和 Sidecar(规划中)这 3 款既能够独立部署,又支持混合部署配合使用的产品组成. 它们均提供标准化的基 ...

  8. C# 获取指定年月的第一天和最后一天、获取本月的第一天和最后一天、获取当前日期的星期几等

    •获取指定年月的第一天 public static DateTime GetCurMonthFirstDay(string year,string mon) { DateTime AssemblDat ...

  9. 内部网关协议OSPF

    开放最短路径优先OSPF,开放表明OSPF不受某一厂商控制,最短路径优先是因为使用了最短路径算法SPF. OSPF最主要的特征是使用链路状态协议,而不是RIP的距离向量路由协议.其余特点: ⑴使用洪泛 ...

  10. thinkphp5 关于跨域的一些坑

    1.首先在tp5的入口文件:public/index.php 在里面添加三行: // [ 应用入口文件 ] header("Access-Control-Allow-Origin:*&quo ...