但是在我们常见的某些应用,比如Excel的表格中,我们发现表并不一定是线性表,Excel中的表就明显是二维的结构 ? 那么在数据结构中,我们会使用这种广义上的表吗?...答案是会,我们也会、或者说我们也能使用这样的非线性表。其实我们早就已经在使用这样的非线性表、广义表了,那就是多维数组。不难发现二维数组就可以抽象成Excel当中的表的样子。...那么,广义表的定义是怎样的呢?...可能会有人发现一个小小的问题,就是为什么我又将广义表叫作多重表呢?...(存储学生选课的抽象的二维多重表,横向代表学生A,B,C……纵向代表课程1,2,3……,若某一项打勾则表示该学生选了该课程,比如若A1打勾则表示学生A选择了课程1) 但是,现在情况有了新条件,这一所大学我们知道三个信息
01 广义表的定义 1、广义表是线性表的推广,也有人称其为列表(lists,用复数形式以示与统称的表list的区别)。广泛地用于人工智能等领域的表处理语言LISP语言,把广义表作为基本的数据结构。...02 广义表的存储结构 1、由广义表(a1,a2,a3...an)中的数据元素可以具有不同的结构(或是原子,或是列表),因此难以用顺序存储结构表示,通常采用链式存储结构,每个数据元素可用一个结点表示。...2、由于列表中的数据元素可能为原子或列表,由此需要两种数据结构的结点:一种是表结点,用以表示列表;一种是原子结点,用以表示原子。 3、若列表不空,则可分解成表头和表尾。...由此,一个表结点可由3个域组成:标志域、指示表头的指针域和指示表尾的指针域;而原子结点只需两个域:标志域和值域。 如果您觉得本篇文章对您有作用,请转发给更多的人,点一下好看就是对小编的最大支持!
三、广义表 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),利用链表存储的逻辑图如下: ? 广义表可以采用多种方式实现,最简单的方法是使用数组实现。
---- 简单的哈希表的实现,c语言。 哈希表原理 哈希表是为了根据数据的部分内容(关键字),直接计算出存放完整数据的内存地址。...下图是一个哈希表运行时内存布局: 先说一下原理。 先是有一个bucket数组,也就是所谓的桶。 哈希表的特点就是数据与其在表中的位置存在相关性,也就是有关系的,通过数据应该可以计算出其位置。...} index >>= 27; index &= (BUCKETCOUNT - 1); return index; } 辅助函数strDup 这是比较多余的做法,因为C标准库中...因为这个哈希表中保存的是键值对,所以这个方法是从哈希表中查找key对应的value的。...insertEntry(&t , "显卡" , "NVIDIA GeForce GTX 850M (2 GB / 华硕)"); insertEntry(&t , "显示器" , "奇美 CMN15C4
01广义表的定义 1、广义表是线性表的推广,也有人称其为列表(lists,用复数形式以示与统称的表list的区别)。广泛地用于人工智能等领域的表处理语言LISP语言,把广义表作为基本的数据结构。...02广义表的存储结构 1、由广义表(a1,a2,a3...an)中的数据元素可以具有不同的结构(或是原子,或是列表),因此难以用顺序存储结构表示,通常采用链式存储结构,每个数据元素可用一个结点表示。...4、以广义表为例,如何利用分治法进行递归算法设计。通常可以先写出问题求解的递归定义,和第二数学归纳法类似,递归定义由基本项和归纳项两部分组成。...6、广义表的深度定义为广义表中括弧的重数,是广义表的一种量度。 7、任何一个非空广义表均可分解成表头和表尾,反之,一对确定的表头和表尾可唯一确定一个广义表。...C语言 | 求特定规律数的和 更多案例可以go公众号:C语言入门到精通
01 广义表 1、递归函数结构清晰、程序易读,且容易证明正确性,因此是程序设计的有力工具。 2、有时递归函数的执行效率很低,因此使用递归应该扬长避短。在程序设计中,不应该一味追求递归。...4、以广义表为例,如何利用分治法进行递归算法设计。通常可以先写出问题求解的递归定义,和第二数学归纳法类似,递归定义由基本项和归纳项两部分组成。...6、广义表的深度定义为广义表中括弧的重数,是广义表的一种量度。 7、任何一个非空广义表均可分解成表头和表尾,反之,一对确定的表头和表尾可唯一确定一个广义表。
【线性表】之顺序表 线性表 线性表(linear list)是n个具有相同特性元素的有限序列 。...线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串… 线性表在逻辑上是线性结构,也就说是连续的一条直线。...但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。 顺序表 它是最简单的数据结构,也是最常用的数据结构——他的作用就是将数据存起来。...概念:顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。 顺序表一般可分为: 1.静态顺序表:使用定长数据存储。...2.动态顺序表:使用动态开辟的数组存储。
前言 C语言的水深不见底,好在一些前辈们已经将很多雷区探了一遍 这里分享一下我在学习 《C语言深度解剖》 过程中的一些笔记和心得 ---- 概要 ---- typedef typedef 从字面上理解...: syntax error : identifier 'k' //error C2059: syntax error : ';' //error C2513: '/*global*/...int a[10]; int a; a b[10]; a b; a* b[10]; a* b; 以上的实例,实话说我目前还没完全理清,先记录下来,慢慢研究,准备专门开一篇来详细探究 ---- 注释 C语言里有两中注释方式...; //error C2065: 'in' : undeclared identifier //error C2146: syntax error : missing ';' before...identifier 't' //error C2065: 't' : undeclared identifier //error C2146: syntax error
为当前线性表的长度 int listSize; //listSize为线性表的总长度 } SqList; /*创建线性表 */ void initList(SqList...(ElemType *)malloc(L->listSize * sizeof(ElemType)); //为线性表申请内存空间,大小为线性表的总长度 乘以 每一个元素所占空间的大小 L...printf("创建线性表后\n线性表的当前长度:%d", L.length); printf("\n线性表的总长度:%d", L.listSize); if(listEmpty...(&L)){ //判断表是否为空 printf("\n此时线性表为空"); } else { printf("\n此时线性表不为空");...:%d\n", L.length); listTraverse(&L); scanf("%c", &ch); return 0; }
一、概念 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。 顺序表一般分为 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,需要写一部分,编译一部分,这样才更加的有持续性。
SL* ps, SeqListType x);//头插 //头销 & 尾销 void SLPopBack(SL* ps);//尾 void SLPopFront(SL* ps);//头 这是SL.c文件
前言 C语言的水深不见底,好在一些前辈们已经将很多雷区探了一遍 这里分享一下我在学习 《C语言深度解剖》 过程中的一些笔记和心得 ---- 概要 ---- 指针与数组 #include <stdio.h...理解为结构体名,同时其值为&a[0] a+1,是数组下一元素的首地址,即 a[1]的首地址 #include void main() { char a[5]={'a','b','c'...a[5][5]; int (*p)[4]; p=a; printf("a_ptr=%#p,p_ptr=%#p\n",&a[4][2],&p[4][2]); // a_ptr=0X0018FF3C,...p_ptr=0X0018FF2C printf("%p,%d\n",&p[4][2]-&a[4][2],&p[4][2]-&a[4][2]); //FFFFFFFC,-4 } &a[4][2] 表示
前言 C语言的水深不见底,好在一些前辈们已经将很多雷区探了一遍 这里分享一下我在学习 《C语言深度解剖》 过程中的一些笔记和心得 ---- 概要 ---- 数组参数与指针参数 C语言中,当一维数组作为函数参数的时候
前言 C语言的水深不见底,好在一些前辈们已经将很多雷区探了一遍 这里分享一下我在学习 《C语言深度解剖》 过程中的一些笔记和心得 ---- 概要 ---- const 准确来说 const 是只读的意思...: l-value specifies const object //b=4; //error C2166: l-value specifies const object //c=5; //error...C2166: l-value specifies const object //array[0]=6; //error C2166: l-value specifies const object...=10; //p3=&x; //error C2166: l-value specifies const object u=11; //*p4=12; //error C2166: l-value...int a; c.i=1; a=c.ch; //如果a为1就说明系统是小端模式,如果a为0就说明是大端模式 } 分析下面的输出 #include void main() {
指针是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有四个形参。
头文件 list.h #define MaxSize 50 //表长度的初始定义 typedef struct{ ElemType data[MaxSize]; //顺序表的元素 int length...; //顺序表的当前长度 }SqList; //顺 序表的类型定义 //初始化 int Initiate(SqList &L) { L.length=...int x; Initiate(mylist); for(int i=1;i<11;i++)//这里插入了1-10这10个值 { ListInsert(mylist,i,i); } //输出顺序表中的所有元素
前言 C语言的水深不见底,好在一些前辈们已经将很多雷区探了一遍 这里分享一下我在学习 《C语言深度解剖》 过程中的一些笔记和心得 ---- 概要 ---- sizeof sizeof是关键字,而不是函数...main() { int i=0; int a=sizeof(int); // 4 ,因为int类型占4个字节 int b=sizeof(i); // 4 ,因为i为int类型,占4个字节 int c=...sizeof i; //4 这个写法也是可以的与上面的相同 // int d=sizeof int; //error C2059: syntax error : 'type' } Tip: 在VC++... #include int main() { float *p1; int *p2; void *p3; //p1=p2; //warning C4133...- from 'int *' to 'float *' p1=(float*)p2; //经过转化是可以的 p2=(int*)p1; //经过转化是可以的 //p2=p1; //warning C4133
一、顺序表的概念及结构 线性表 线性表(linearlist)是n个具有相同特性的数据元素的有限序列。线性表是⼀种在实际中⼴泛使⽤的数据结构,常⻅的线性表:顺序表、链表、栈、队列、字符串......线性表在逻辑上是线性结构,也就说是连续的⼀条直线。但是在物理结构上并不⼀定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。...二、顺序表分类 顺序表和数组的区别: 顺序表的底层结构是数组,对数组的封装,实现了常⽤的增删改查等接口,逻辑结构是线性,且物理结构也是线性。...1、静态顺序表:使用定长数组存储元素 静态顺序表缺陷:空间给少了不够⽤,给多了造成空间浪费 2、动态顺序表:按需申请 3、动态顺序表的实现 #define INIT_CAPACITY 4 typedef...size - 1] = -1; ps->size--; } 四、头删 顺序表为空:不能执行删除操作; 顺序表不为空:后面的数据往前挪动一位。
他是用下面这一张表来证明这一命题的: 我们以 Z 字形给上表的每一项编号。...输出格式 表中的第 N 项。
线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串等… 线性表在逻辑上是线性结构,也就说是连续的一条直线。...顺序表一般分为;两种: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)
领取专属 10元无门槛券
手把手带您无忧上云