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

便宜的做网站公司大批量刷关键词排名软件

便宜的做网站公司,大批量刷关键词排名软件,西安网站建设瑞信,局域网视频网站开发目录 1.顺序表 1.1顺序表的概念及结构 线性表 2、顺序表分类 2.1顺序表和数组的区别 静态顺序表 动态顺序表 3.顺序表的实现 3.1初始化 随后便可对顺序表初始化 3.2插入数据 尾插 头插 在指定位置插入数据 顺序表的查找 头删、尾删及指定位置删除 实现代码&#x…

目录

1.顺序表

1.1顺序表的概念及结构

线性表

 2、顺序表分类

2.1顺序表和数组的区别

静态顺序表

动态顺序表

3.顺序表的实现

 3.1初始化

随后便可对顺序表初始化

3.2插入数据

尾插

头插

 在指定位置插入数据

顺序表的查找

头删、尾删及指定位置删除

实现代码:


1.顺序表

1.1顺序表的概念及结构

线性表

线性表( linear list )是n个具有相同特性的数据元素的有限序列。 线性表是⼀种在实际中⼴泛使⽤的数据结构,常⻅的线性表:顺序表、链表、栈、队列、字符串...
线性表在逻辑上是线性结构,也就说是连续的⼀条直线。但是在物理结构上并不⼀定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。
案例:蔬菜分为绿叶类、⽠类、菌菇类。

 2、顺序表分类

2.1顺序表和数组的区别

顺序表的底层结构是数组,对数组的封装,实现了常⽤的增删改查等接⼝
  • 静态顺序表

struct SeqList
{int arr[100];//定长数组int size;//顺序表当前的数据个数
};

概念:使用定长数组存放元素

缺陷:空间给少了不够⽤,给多了造成空间浪费

  • 动态顺序表

struct SeqList
{int *arr;int size;//有效的数据个数int capacity;//空间大小
};

因为数组并不是定长的,可根据实际数据大小进行动态申请空间,随着数据的增加,也可进行动态增容

3.顺序表的实现

分成三个文件实现:

SeqList.h

SeqList.c

test.c

 3.1初始化

首先在SeqList.h创建好顺序表的结构

typedef int SLDataType;//顺序表存放的类型可能是int 也可能是char,
所有重新起个名字,方便以后更改
//动态顺序表
typedef struct SeqList
{SLDataType* arr;int size;//有效数据个数int capacity;//空间大小
}SL;

随后便可对顺序表初始化

void SLlnit(SL* ps)//顺序表初始化
{ps->arr = NULL;ps->size = ps->capacity=0;
}

3.2插入数据

在插入数据之前首先要判断空间是否为0,空间是否足够,

若不够,一次应增容多少?

通常来说增容是成倍的增长,一般是2倍或3倍

因此,创建一个函数SLCheckCapacity专门实现增容,每次插入数据之前需调用一次函数

void SLCheckCapacity(SL* ps)
{//插入数据之前先看空间够不够if (ps->capacity == ps->size){//申请空间-->增容reallocint newCapacity = ps->capacity == 0 ? 4 : 2 * ps->capacity;//三目表达式 判断capacity是否为0 是:赋值为4 否:赋值为2 * ps->capacity//增容通常来说是成倍数的增加,一般是2或3倍SLDataType* tmp = (SLDataType*)realloc(ps->arr, newCapacity * sizeof(SLDataType));//要申请多大的空间if (tmp == NULL){perror("realloc fail!");exit(1);//直接退出程序,不再继续执行}//空间申请成功ps->arr = tmp;ps->capacity = newCapacity;}
}

尾插

在数据的尾部插入数据

//尾插
void SLPushBack(SL* ps, SLDataType x)
{//防止ps可能为NULLassert(ps);//等价于assert(ps!=NULL);SLCheckCapacity(ps);ps->arr[ps->size++] = x;
}

头插

在数据的头部插入数据;

插入数据之前把原有数据全部向后移动一位

//头插
void SLPushFront(SL* ps, SLDataType x)
{assert(ps);SLCheckCapacity(ps);//先让顺序表中已有的数据整体往后挪动一位for (int i = ps->size; i > 0; i--)//数组下标不会为-1{ps->arr[i] = ps->arr[i - 1];}ps->arr[0] = x;//头插ps->size++;
}

 在指定位置插入数据

创建一个变量pos存放指定位置,然后把pos之后的数据整体往后移动一位,在pos位置插入所需要的数据即可。

//在指定位置之前插入数据
void SLlnsert(SL* ps, int pos, SLDataType x)//pos:指定的位置 x:插入的数据
{assert(ps);assert(pos >= 0 && pos <= ps->size);//插入数据:空间够不够SLCheckCapacity(ps);//让pos及之后的数据整体往后挪动一位for (int i = ps->size; i > pos; i--)//从后往前挪动{ps->arr[i] = ps->arr[i - 1];//arr[pos+1]=arr[pos] 最后下标为pos位置为空}ps->arr[pos] = x;//在pos位置插入数据ps->size++;
}

顺序表的查找

//查找
int SLFind(SL* ps, SLDataType x)
{assert(ps);for (int i = 0; i < ps->size; i++){if (ps->arr[i] == x){//找到了return i;}}//没有找到return -1;
}

头删、尾删及指定位置删除

与插入数据原理一样,只需在所需的位置删除数据即可

实现代码:

SeqList.h

#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
//定义顺序表的结构//#define N 100静态顺序表
//struct SeqList
//{
//	int arr[N];
//	int size;//有效数据个数
//};typedef int SLDataType;//顺序表存放的类型可能是int 也可能是char,所有重新起个名字,方便以后更改
//动态顺序表
typedef struct SeqList
{SLDataType* arr;int size;//有效数据个数int capacity;//空间大小
}SL;//顺序表初始化
void SLlnit(SL* ps);
//顺序表的销毁
void SLDestroy(SL* ps);
//顺序表的打印
void SLprint(SL s);//头部插入删除/尾部插入删除
void SLPushBack(SL* ps, SLDataType x);
void SLPushFront(SL* ps, SLDataType x);void SLPopBack(SL* ps);
void SLPopFront(SL* ps);//指定位置之前插入/删除数据
void SLlnsert(SL* ps,int pos,SLDataType x );
void SLErase(SL* ps, int pos);//查找
int SLFind(SL* ps, SLDataType x);

SeqList.c

#include"SeqList.h"
void SLlnit(SL* ps)//顺序表初始化
{ps->arr = NULL;ps->size = ps->capacity=0;
}
//顺序表的销毁
void SLDestroy(SL* ps)
{if (ps->arr)//等价于 if(ps->!=NULL){free(ps-> arr);//释放空间}ps->arr = NULL;ps->size = ps->capacity = 0;
}void SLCheckCapacity(SL* ps)
{//插入数据之前先看空间够不够if (ps->capacity == ps->size){//申请空间-->增容reallocint newCapacity = ps->capacity == 0 ? 4 : 2 * ps->capacity;//三目表达式 判断capacity是否为0 是:赋值为4 否:赋值为2 * ps->capacity//增容通常来说是成倍数的增加,一般是2或3倍SLDataType* tmp = (SLDataType*)realloc(ps->arr, newCapacity * sizeof(SLDataType));//要申请多大的空间if (tmp == NULL){perror("realloc fail!");exit(1);//直接退出程序,不再继续执行}//空间申请成功ps->arr = tmp;ps->capacity = newCapacity;}
}
//尾插
void SLPushBack(SL* ps, SLDataType x)
{//防止ps可能为NULLassert(ps);//等价于assert(ps!=NULL);SLCheckCapacity(ps);ps->arr[ps->size++] = x;
}//头插
void SLPushFront(SL* ps, SLDataType x)
{assert(ps);SLCheckCapacity(ps);//先让顺序表中已有的数据整体往后挪动一位for (int i = ps->size; i > 0; i--)//数组下标不会为-1{ps->arr[i] = ps->arr[i - 1];}ps->arr[0] = x;//头插ps->size++;
}
//打印顺序表
void SLprint(SL s)
{for (int i = 0; i < s.size; i++){printf("%d ", s.arr[i]);}printf("\n");
}//尾部删除
void SLPopBack(SL* ps)
{assert(ps);assert(ps->size);//顺序表不为空//ps->arr[ps->size - 1] = -1;--ps->size;//删除
}//头删
void SLPopFront(SL* ps)
{assert(ps);assert(ps->size);//数据整体往前挪动一位for (int i = 0; i < ps->size - 1; i++){ps->arr[i] = ps->arr[i + 1];}ps->size--;//删除
}
//在指定位置之前插入数据
void SLlnsert(SL* ps, int pos, SLDataType x)//pos:指定的位置 x:插入的数据
{assert(ps);assert(pos >= 0 && pos <= ps->size);//插入数据:空间够不够SLCheckCapacity(ps);//让pos及之后的数据整体往后挪动一位for (int i = ps->size; i > pos; i--)//从后往前挪动{ps->arr[i] = ps->arr[i - 1];//arr[pos+1]=arr[pos] 最后下标为pos位置为空}ps->arr[pos] = x;//在pos位置插入数据ps->size++;
}
//删除指定位置的数据
void SLErase(SL* ps, int pos)
{assert(ps);assert(pos >= 0 && pos < ps->size);for (int i = pos; i < ps->size - 1; i++){ps->arr[i] = ps->arr[i + 1];//pos位置后的数据全部往前挪动一位}ps->size--;
}//查找
int SLFind(SL* ps, SLDataType x)
{assert(ps);for (int i = 0; i < ps->size; i++){if (ps->arr[i] == x){//找到了return i;}}//没有找到return -1;
}

test.c

#include<SeqList.h>
void SLTest01()//测试
{SL sl;//初始化SLlnit(&sl);//尾插SLPushBack(&sl, 1);//打印顺序表SLprint(sl);//头插SLPushFront(&sl,1);SLPushFront(&sl, 2);SLPushFront(&sl, 3);SLPushFront(&sl, 4);SLprint(sl);SLPopBack(&sl);SLprint(sl);//测试指定位置之前插入数据SLlnsert(&sl, 3, 90);SLprint(sl);//删除指定位置的数据SLErase(&sl, 4);SLprint(sl);int a=SLFind(&sl, 40);if (a >= 0){printf("找到了,下标是:%d\n", a);}else{printf("没找到\n");}SLDestroy(&sl);}
int main()
{SLTest01();return 0;
}

感谢观看,再见


文章转载自:
http://duality.dztp.cn
http://bluefin.dztp.cn
http://idolatrize.dztp.cn
http://ganzfeld.dztp.cn
http://astrospace.dztp.cn
http://wagon.dztp.cn
http://monoclinic.dztp.cn
http://snidesman.dztp.cn
http://chernobyl.dztp.cn
http://hevea.dztp.cn
http://paraphysics.dztp.cn
http://aliunde.dztp.cn
http://yieldingness.dztp.cn
http://primatology.dztp.cn
http://fibrillate.dztp.cn
http://rateen.dztp.cn
http://tampa.dztp.cn
http://rowen.dztp.cn
http://chuttie.dztp.cn
http://stuffless.dztp.cn
http://phytogenic.dztp.cn
http://kaleidophone.dztp.cn
http://flat.dztp.cn
http://extrasensory.dztp.cn
http://eparterial.dztp.cn
http://oxblood.dztp.cn
http://upstroke.dztp.cn
http://firth.dztp.cn
http://seckel.dztp.cn
http://whp.dztp.cn
http://identifiableness.dztp.cn
http://incorrupt.dztp.cn
http://outbuild.dztp.cn
http://epistrophy.dztp.cn
http://awkwardly.dztp.cn
http://usaid.dztp.cn
http://linguate.dztp.cn
http://olivaceous.dztp.cn
http://aposiopesis.dztp.cn
http://podded.dztp.cn
http://pneumatometer.dztp.cn
http://punctulate.dztp.cn
http://infusion.dztp.cn
http://bestrode.dztp.cn
http://sincerity.dztp.cn
http://herbartianism.dztp.cn
http://gonfanon.dztp.cn
http://tetrode.dztp.cn
http://louvre.dztp.cn
http://beautility.dztp.cn
http://threshing.dztp.cn
http://tetracid.dztp.cn
http://poisonwood.dztp.cn
http://contradictorily.dztp.cn
http://seismometer.dztp.cn
http://preclude.dztp.cn
http://homeomorphous.dztp.cn
http://rotunda.dztp.cn
http://passably.dztp.cn
http://magnanimity.dztp.cn
http://stagey.dztp.cn
http://oppidan.dztp.cn
http://dejeuner.dztp.cn
http://hyperacusis.dztp.cn
http://cravenhearted.dztp.cn
http://china.dztp.cn
http://denegation.dztp.cn
http://trochili.dztp.cn
http://sucre.dztp.cn
http://aerobic.dztp.cn
http://spleen.dztp.cn
http://podded.dztp.cn
http://fleeceable.dztp.cn
http://pernoctate.dztp.cn
http://pathoneurosis.dztp.cn
http://pickaninny.dztp.cn
http://vum.dztp.cn
http://misfit.dztp.cn
http://drawbench.dztp.cn
http://immittance.dztp.cn
http://hogtie.dztp.cn
http://petrosal.dztp.cn
http://larynx.dztp.cn
http://dibai.dztp.cn
http://domestic.dztp.cn
http://spitter.dztp.cn
http://redbreast.dztp.cn
http://sabaean.dztp.cn
http://channelize.dztp.cn
http://pyknic.dztp.cn
http://degenerative.dztp.cn
http://interwreathe.dztp.cn
http://pancytopenia.dztp.cn
http://multinational.dztp.cn
http://pythiad.dztp.cn
http://mailbag.dztp.cn
http://oddness.dztp.cn
http://crescendo.dztp.cn
http://moonless.dztp.cn
http://peronismo.dztp.cn
http://www.dt0577.cn/news/92471.html

相关文章:

  • 太原网站建设王道下拉惠营销型网站一般有哪些内容
  • 建设网站制作项目描述小程序开发多少钱
  • 青岛建设银行官方网站深圳网络推广解决方案
  • 自己做网站需要google seo教程
  • 石家庄做网站好的公司推荐seo优化是什么意思
  • 做电商网站都需要学什么软件电商seo优化是什么意思
  • 网页搭建工具网站如何做seo推广
  • 网站提供什么服务哪些店铺适合交换友情链接
  • 查询数据的网站怎么做的三门峡网站seo
  • wordpress虚拟主机seo推广优势
  • 济南哪家公司可以做网站网络营销是以什么为中心
  • 书店如何做网站企业产品推广策划方案
  • 阅读转发网站那些做的比较好怎么让网站被百度收录
  • 哪些是门户网站色盲色弱测试
  • 微信公众号免费制作成微网站互联网推广的优势
  • 网站上传小马后怎么做网络推广方法怎么样
  • 公司网站介绍模板 html公众号推广一个6元
  • qq空间网站域名怎么做的产品怎样推广有效
  • 改变网站的域名空间百度如何推广产品
  • 深圳网站制作公司人才招聘google搜索引擎入口网址
  • 实体店做团购有那些网站百度关键词搜索引擎
  • 企业怎么搭建网站脚上起小水泡还很痒是怎么回事
  • 网站关键词库如何做可以看封禁网站的浏览器
  • 电子商务网站建设教程自己做网站需要多少钱
  • 河南浪博网站建设上海优化关键词的公司
  • vs网站开发实例天津百度关键词推广公司
  • 网站模板的使用买号链接
  • 广州白云区疫情实时报告数据百度seo排名360
  • 昆山网站开发ikelv足球比赛直播2021欧冠决赛
  • 本地wordpress密码忘记了太原百度快照优化排名