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

多重广义

但是在我们常见的某些应用,比如Excel的表格中,我们发现并不一定是线性,Excel中的就明显是二维的结构 ? 那么在数据结构中,我们会使用这种广义上的吗?...答案是会,我们也会、或者说我们也能使用这样的非线性。其实我们早就已经在使用这样的非线性广义了,那就是多维数组。不难发现二维数组就可以抽象成Excel当中的的样子。...那么,广义的定义是怎样的呢?...可能会有人发现一个小小的问题,就是为什么我又将广义叫作多重呢?...(存储学生选课的抽象的二维多重,横向代表学生A,B,C……纵向代表课程1,2,3……,若某一项打勾则表示该学生选了该课程,比如若A1打勾则表示学生A选择了课程1) 但是,现在情况有了新条件,这一所大学我们知道三个信息

1.1K20

5.4 广义

01 广义的定义 1、广义是线性的推广,也有人称其为列表(lists,用复数形式以示与统称的list的区别)。广泛地用于人工智能等领域的处理语言LISP语言,把广义作为基本的数据结构。...02 广义的存储结构 1、由广义(a1,a2,a3...an)中的数据元素可以具有不同的结构(或是原子,或是列表),因此难以用顺序存储结构表示,通常采用链式存储结构,每个数据元素可用一个结点表示。...2、由于列表中的数据元素可能为原子或列表,由此需要两种数据结构的结点:一种是结点,用以表示列表;一种是原子结点,用以表示原子。 3、若列表不空,则可分解成表头和尾。...由此,一个结点可由3个域组成:标志域、指示表头的指针域和指示尾的指针域;而原子结点只需两个域:标志域和值域。 如果您觉得本篇文章对您有作用,请转发给更多的人,点一下好看就是对小编的最大支持!

5243129
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数组和广义

    三、广义 1.定义 广义是线性的扩展,具体定义为n(n≥0)个元素的有限集合。 n的值是广义的长度,如果n=0称广义为空。...广义一般记作:LS=(a1,a2,……,an) 常见的广义为:A=()、B=(())、C=(a,b)、D=(A,B,C)、E=(a,E) 广义中含有元素的个数称为广义的长度,广义中含有的括号对数称为广义深度...广义有三个重要的特点: 第一:广义的元素可以是子表,而子表的元素还可以是子表,广义是一个多层次的结构。 第二:广义可以为其他广义所共享。...第三:广义可以是一个递归,即也可以是其本身的一个子表。 广义的表头是广义中的第一个元素,而尾则是去掉表头之后的所有元素。 广义中通常利用求表头和尾运算求得广义中某个元素的值。...link表示指针,指向广义的下一个元素。 例如:广义A=(a,(b,(c)),(d,e),f),利用链表存储的逻辑图如下: ? 广义可以采用多种方式实现,最简单的方法是使用数组实现。

    74820

    C语言实现哈希_哈希c语言代码

    ---- 简单的哈希的实现,c语言。 哈希原理 哈希是为了根据数据的部分内容(关键字),直接计算出存放完整数据的内存地址。...下图是一个哈希运行时内存布局: 先说一下原理。 先是有一个bucket数组,也就是所谓的桶。 哈希的特点就是数据与其在中的位置存在相关性,也就是有关系的,通过数据应该可以计算出其位置。...} index >>= 27; index &= (BUCKETCOUNT - 1); return index; } 辅助函数strDup 这是比较多余的做法,因为C标准库中...因为这个哈希中保存的是键值对,所以这个方法是从哈希中查找key对应的value的。...insertEntry(&t , "显卡" , "NVIDIA GeForce GTX 850M (2 GB / 华硕)"); insertEntry(&t , "显示器" , "奇美 CMN15C4

    4.9K20

    5.3 数据结构广义

    01广义的定义 1、广义是线性的推广,也有人称其为列表(lists,用复数形式以示与统称的list的区别)。广泛地用于人工智能等领域的处理语言LISP语言,把广义作为基本的数据结构。...02广义的存储结构 1、由广义(a1,a2,a3...an)中的数据元素可以具有不同的结构(或是原子,或是列表),因此难以用顺序存储结构表示,通常采用链式存储结构,每个数据元素可用一个结点表示。...4、以广义为例,如何利用分治法进行递归算法设计。通常可以先写出问题求解的递归定义,和第二数学归纳法类似,递归定义由基本项和归纳项两部分组成。...6、广义深度定义为广义中括弧的重数,是广义的一种量度。 7、任何一个非空广义均可分解成表头和尾,反之,一对确定的表头和尾可唯一确定一个广义。...C语言 | 求特定规律数的和 更多案例可以go公众号:C语言入门到精通

    7862723

    【线性】之顺序(C语言)

    【线性】之顺序 线性 线性(linear list)是n个具有相同特性元素的有限序列 。...线性是一种在实际中广泛使用的数据结构,常见的线性:顺序、链表、栈、队列、字符串… 线性在逻辑上是线性结构,也就说是连续的一条直线。...但是在物理结构上并不一定是连续的,线性在物理上存储时,通常以数组和链式结构的形式存储。 顺序 它是最简单的数据结构,也是最常用的数据结构——他的作用就是将数据存起来。...概念:顺序是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。 顺序一般可分为: 1.静态顺序:使用定长数据存储。...2.动态顺序:使用动态开辟的数组存储。

    62410

    C语言手撕顺序

    一、概念 顺序是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。 顺序一般分为 1、静态顺序:使用定长数组存储元素。...2、动态顺序:使用动态开辟的数组存储 我们一般使用动态顺序,因为静态顺序的数组大小固定的,而动态可以根据我们需求的不同去在线扩容,所以接下来的文章围绕如何实现动态顺序来讲解。...);//头删 void SeqListPopBack(SeqList* ps);//尾删 void SeqListCheckCapacity(SeqList* ps);//检查是否需要扩容 // 顺序查找...int SeqListFind(SeqList* ps, SLDateType x); // 顺序在pos位置插入x void SeqListInsert(SeqList* ps, int pos,...心得: 顺序开启了数据结构的的序章,顺序算是很简单的数据结构了,从此我们需要敲一部分代码,编译一次,不能一股脑的输出,结果编译发现好多个bug,需要写一部分,编译一部分,这样才更加的有持续性。

    9710

    C语言指针深度解剖

    指针是C语言的灵魂,深入理解指针,是学好学会C语言的重要前提。因此,本文将重点讲解C语言指针的深度内容。 先来简单回顾一下最基础的关于指针的概念。 简单来说,指针就是地址。...字符指针 char ch = 'w'; char* pc = &ch;//char* 是pc的类型,*代表着pc是指针,char代表pc指向的类型是char *pc = 'b'; printf("%c\...所以int(*p)[10] = &arr;要加个数 return 0; } 下面是数组指针的用法: void Print(int(*p)[5], int r, int c) { int i = 0;...for (i = 0; i < r; i++) { int j = 0; for (j = 0; j < c; j++) { printf("%d ", *(*(p + i) +...qsort是C语言的一个排序函数,其排序方法就是使用了快排的思想,可以满足不同使用场景下的排序。 先来看看qsort的函数声明:  可以看到,qsort有四个形参。

    46120

    C语言——S顺序专题

    一、顺序的概念及结构 线性 线性(linearlist)是n个具有相同特性的数据元素的有限序列。线性是⼀种在实际中⼴泛使⽤的数据结构,常⻅的线性:顺序、链表、栈、队列、字符串......线性在逻辑上是线性结构,也就说是连续的⼀条直线。但是在物理结构上并不⼀定是连续的,线性在物理上存储时,通常以数组和链式结构的形式存储。...二、顺序分类 顺序和数组的区别: 顺序的底层结构是数组,对数组的封装,实现了常⽤的增删改查等接口,逻辑结构是线性,且物理结构也是线性。...1、静态顺序:使用定长数组存储元素 静态顺序缺陷:空间给少了不够⽤,给多了造成空间浪费 2、动态顺序:按需申请 3、动态顺序的实现 #define INIT_CAPACITY 4 typedef...size - 1] = -1; ps->size--; } 四、头删 顺序为空:不能执行删除操作; 顺序不为空:后面的数据往前挪动一位。

    8410

    线性之顺序(C语言实现)

    线性是一种在实际中广泛使用的数据结构,常见的线性:顺序、链表、栈、队列、字符串等… 线性在逻辑上是线性结构,也就说是连续的一条直线。...顺序一般分为;两种:1.静态顺序 2.动态顺序 静态顺序实际作用不大,本篇主要讲解动态顺序. 2.1 静态顺序简单介绍: 静态顺是指顺序的容量是固定的,如果看过c语言实现通讯录的友友们...false; } 3.6 顺序的删除操作 顺序的"尾删" 顺序的尾删也是很舒服的....PrintSQL(SQL SL); void PrintSQL(SQL* SL); //顺序的销毁 void DestorySQL(SQL SL); 函数实现区(SQList.c) #define...SL) { assert(SL); free(SL->data); SL->data = NULL; SL->size = 0; SL->capacity = 0; } 主测试区(test.c)

    87830
    领券