千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:郑州千锋IT培训  >  技术干货  >  数据结构构造有哪些?

数据结构构造有哪些?

来源:千锋教育
发布人:xqq
时间: 2023-10-14 13:52:55

一、数据结构构造

1、数组类型

数组是有一定顺序关系的若干变量的一个集合,其中每一个变量我们称为数组的元素,分为一维数组、多维数组。一维数组有一个下标就能确定位置。多维数组元素有多个下标,以标识它在数组中的位置。

一维数组

定义:<数据类型> <数组名> < [ ] >  例:int  i [10]。初始化方法:

普通局部数组没有初始化,则数组中元素的值,是不确定的。全局数组没有初始化默认为0。

全部初始化,给每一位元素写值,例:int  i [5]={1,2,3,4,5};还可以写成 int  i []={1,2,3,4,5};两种写法都是5个元素。

局部初始化,只给数组里前几位初始化,不完全初始化,余下的就会默认为0。例:int  i [5]={0};剩下的4位默认为0。int  i [5]={1,2}; 剩下的3位都为0。

二维数组

多维数组要多个下标,二维数组有两个下标,才能确定位置。定义: <数据类型> <数组名> < [ ] >< [ ] >  例:int  i [5][10]; 可以看成是5个一维数组,每个一维数组10个元素。初始化方式:

全部初始化,例:int  i [2][3]={ {1,2,3},{1,2,3} };{}里有两个一维数组。给每个元素赋值。还可以写成 int  i [][3]={ {1,2,3},{1,2,3} };

部分初始化:int  i [2][3]={ {1},{1} };给个每个给前面1个(或多个)元素赋值,名列前茅个一维剩下的3个元素默认为0,第二个也是。

线性赋值,例:int  i [2][3]={1,2,3,1,2,3}; 这里数组共有6个元素,里面不用{}分开,直接给每位元素赋值。

线性部分初始化,例:int  i [2][3]={1,2} ; 剩下的4位元素都默认为0。

2、结构体类型

结构体是C语言中一种重要的数据类型,该数据类型由一组称为成员(或称为域,或称为元素)的不同数据组成,其中每个成员可以具有不同的类型。结构体通常用来表示类型不同但是又相关的若干数据。结构体类型不是由系统定义好的,而是需要程序设计者自己定义的。C语言提供了关键字struct来标识所定义的结构体类型。

关键字struct和结构体名组合成一种类型标识符,其地位如同通常的int、char等类型标识符,其用途就像 int 类型标识符标识整型变量一样可以用来定义结构体变量。定义变量以后,该变量就可以像定义的其他变量一样使用了;成员又称为成员变量,它是结构体所包含的若干个基本的结构类型,必须用“{}”括起来,并且要以分号结束,每个成员应表明具体的数据类型。

3、共用体类型

不同数据类型的数据可以使用共同的存储区域,这种数据构造类型称为共用体,简称共用,又称联合体。共用体在定义、说明和使用形式上与结构体相似。两者本质上的不同仅在于使用内存的方式上。

延伸阅读:

二、数据结构是什么

数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率。 数据结构往往同高效的检索算法和索引技术有关。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

完全二叉树为什么非常适合顺序存储结构?

2023-10-14

数据结构里面pnext与next有什么区别?

2023-10-14

什么叫精益管理?

2023-10-14

最新文章NEW

Java中遍历数据结构Enumeration和Iterator相比有什么不同?

2023-10-14

数组与集合有什么不同?

2023-10-14

ASPICE是什么?

2023-10-14

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>