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

网站建设计划书怎么写百度大数据中心

网站建设计划书怎么写,百度大数据中心,网站产品优化描述,科技公司网站建设方案书模板文章目录🐨0. 前言🎈1. 顺序表的概念及定义🪁2. 接口的声明🪄3. 接口的实现🍅3.1 为何使用断言?🍒3.2 初始化与销毁🍓3.3 尾插与尾删🍉3.4 头插与头删🍹3.5 指…

文章目录

    • 🐨0. 前言
    • 🎈1. 顺序表的概念及定义
    • 🪁2. 接口的声明
    • 🪄3. 接口的实现
      • 🍅3.1 为何使用断言?
      • 🍒3.2 初始化与销毁
      • 🍓3.3 尾插与尾删
      • 🍉3.4 头插与头删
      • 🍹3.5 指定位置插入与删除
      • 🥂3.6 查找元素
    • 🥊4. 接口测试

在这里插入图片描述

🐨0. 前言

  • 线性表是一种最常用且最简单的一种数据结构。简单来说线性表是n个具有相同特性的数据元素的有序序列,即存在唯一的开始元素和一个终止元素,除开始元素和终止元素外,每个元素都有一个前驱元素和一个后继元素。
  • 线性表是一种在实际中广发使用的数据结构,常见的线性表有:顺序表、链表、栈、队列、字符串…
  • 线性表是在逻辑上是线性结构,但在物理结构上不一定连续,线性表在物理上存储时,通常以数组和链式结构的形式进行存储。

在这里插入图片描述

本篇文章则讲解的是顺序表

🎈1. 顺序表的概念及定义

顺序表指的是用一组地址连续的存储单元依次存储元素的线性结构,一般情况采用数组存储
数组存储的是类型相同的元素,那顺序表,则完全符合要求。所以我们的顺序采用数组来进行存储。

顺序表可分为两种:

  1. 静态顺序表:使用定长数组存储元素。
  2. 动态顺序表:使用开辟动态的数组存储。

那么用哪种更好一点呢?如果用静态顺序表存储,假设指定数组的长度为1000,那么如果想要存放2000个数据,则无法存放;那假设指定长度为2000,那确实可以存放2000个数据,但是,如果我们只存储100个数据呢?这是不是就造成了空间的浪费。这使得我们十分难受,开多了资源浪费,开少了不够用。动态顺序表则可以很好的解决这个问题,可以按需申请。本篇主要讲解的动态顺序表的实现。

🪁2. 接口的声明

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
//动态顺序表
typedef int SLDateType;
#define INIT_CAPACITY 4 //初始化容量
typedef struct SeqList
{SLDateType* a;SLDateType size;//有效数据个数SLDateType capacity;//空间容量
}SL;//增删查改//初始化顺序表
void SLInit(SL* s); 
//销毁顺序表
void SLDestroy(SL* s);
//打印顺序表
void SLPrint(SL* s);
//尾插
void SLPushBack(SL* s, SLDateType x);
//尾删
void SLPopBack(SL* s);
//头插
void SLPushFront(SL* s,SLDateType x);
//头删
void SLPopFront(SL* s);
//指定位置插入
void SLInsert(SL* s, int pos, SLDateType x);
//指定位置删除
void SLErase(SL* s, int pos);
//查找元素
int SLFind(SL* s, SLDateType x);

这个顺序表不是结构体,而是结构体里面的a,指向了顺序表向内存申请的空间,size表示当前顺序表里面已经存放了多少个数据,capacity表示当前顺序表的总容量。
在这里插入图片描述

🪄3. 接口的实现

🍅3.1 为何使用断言?

这里如果传空指针,程序会继续执行,那么最后会挂掉。然而我们不知道程序是在哪出错,还得一步一步调试找出问题。使用断言则会直接报错,并告诉我们错误所出现的位置。

使用断言的好处:
帮助程序员发现并修复程序中的错误,提高代码质量和可读性,同时也可以帮助程序员更好地设计程序,提高程序的正确性和可靠性。

🍒3.2 初始化与销毁

//初始化
void SLInit(SL* s)
{aassert(s);s->a = (SLDateType*)malloc(sizeof(SLDateType) * INIT_CAPACITY);if (s->a == NULL){perror("malloc fail");return;}s->size = 0;s->capacity = INIT_CAPACITY;
}//销毁顺序表
void SLDestroy(SL* s)
{assert(s);free(s->a);s->a = NULL;s->capacity = 0;s->size = 0;
}

🍓3.3 尾插与尾删

//容量检查
void SLCheackCapacity(SL* ps)
{assert(ps);if (ps->size == ps->capacity){//扩容//用临时变量接收,防止扩容失败,导致之前的数据丢失SLDateType* tmp = (SLDateType*)realloc(ps->a, sizeof(SLDateType) * 2 * ps->capacity);if (tmp == NULL){perror("realloc fail");return;}ps->a = tmp;ps->capacity *= 2;}
}//尾插
void SLPushBack(SL* ps, SLDateType x)
{assert(ps);//检查容量SLCheackCapacity(ps);ps->a[ps->size] = x;ps->size++;
}//尾删
void SLPopBack(SL* ps)
{assert(ps->size);ps->size--;
}

📝小贴士:
1.因为是动态顺序表,所以每次添加数据的时候需要确实容量是否够用。
2.在进行尾删的时候,如果顺序表里面,没有内容,则不必进行删除,所以需要断言判断,顺序表里面是否还有数据。

🍉3.4 头插与头删

//头插
void SLPushFront(SL* ps, SLDateType x)
{assert(ps);SLCheackCapacity(ps);int end = ps->size - 1;while (end >= 0){//将顺序表元素往后偏移ps->a[end + 1] = ps->a[end];end--;}//直接覆盖ps->a[0] = x;ps->size++;
}//头删
void SLPopFront(SL* ps)
{assert(ps);assert(ps->size > 0);int start = 0;while (start < ps->size-1){ps->a[start] = ps->a[start+1];start++;}ps->size--;
}

头插和头删,每次都需要挪动数据,效率比较低,由此看来,顺序表并不是很适合头插与头删。

头插/头删时间复杂度:O(n2)
尾插/尾删时间复杂度:O(n)

🍹3.5 指定位置插入与删除

//指定位置插入
void SLInsert(SL* ps, int pos, SLDateType x)
{assert(ps);assert(pos >= 0 && pos <= ps->size);SLCheackCapacity(ps);int end = ps->size - 1;while (end >= pos){//从后往前挪动ps->a[end+1] = ps->a[end];end--;}ps->a[pos] = x;ps->size++;
}//指定位置删除
void SLErase(SL* ps, int pos)
{assert(ps);assert(pos >= 0 && pos < ps->size);int start = pos;while (start < ps->size - 1){ps->a[start] = ps->a[start + 1];start++;}ps->size--;
}

其实当我们实现指定位置插入删除之后,那么就可以取代我们前面写的头插(删)、尾插(删)。

//尾插
SLInsert(ps, ps->size, x);
//尾删
SLErase(ps, ps->size - 1);
//头插
SLInsert(ps, 0, x);
//头删
SLInsert(ps, 0, x);

🥂3.6 查找元素

//查找元素
int SLFind(SL* ps, SLDateType x)
{assert(ps);for (int i = 0; i < ps->size; i++){if (ps->a[i] == x){return i;}}return -1;
}

🥊4. 接口测试

我们在实现各个接口功能的时候,如果一次性写完,这很难以保证不出bug,所以我们可以编写边测试,以便于我们更清楚的知道程序每个功能是否完善。

#include"SeqList.h"void TestSeqList1()
{SL s;//初始化测试SLInit(&s);//尾插测试for (int i = 0; i < 10; i++){SLPushBack(&s, i);}SLPrint(&s);//尾删测试for (int i = 0; i < 10; i++){SLPopBack(&s);}SLPrint(&s);//头插测试for (int i = 0; i < 10; i++){SLPushFront(&s, i);}SLPrint(&s);//头删测试/*for (int i = 0; i < 10; i++){SLPopFront(&s);SLPrint(&s);}*///指定插入测试for (int i = 0; i < 5; i++){SLInsert(&s, i+1, i);}SLPrint(&s);//指定删除测试SLErase(&s, 2);SLPrint(&s);SLErase(&s, 3);SLPrint(&s);//查找元素测试printf("%d\n", SLFind(&s, 5));
}int main()
{TestSeqList1();return 0;
}

文章转载自:
http://dinnconeorealist.wbqt.cn
http://dinncodicynodont.wbqt.cn
http://dinncoassur.wbqt.cn
http://dinncocitied.wbqt.cn
http://dinncoonchocerciasis.wbqt.cn
http://dinncosquush.wbqt.cn
http://dinncomanwise.wbqt.cn
http://dinncosigniory.wbqt.cn
http://dinncoforficate.wbqt.cn
http://dinncogetatable.wbqt.cn
http://dinncohebdomad.wbqt.cn
http://dinncobobbly.wbqt.cn
http://dinncovoting.wbqt.cn
http://dinncosoothingly.wbqt.cn
http://dinncohillcrest.wbqt.cn
http://dinncoassiduously.wbqt.cn
http://dinncochocolate.wbqt.cn
http://dinncopase.wbqt.cn
http://dinncoago.wbqt.cn
http://dinncoh.wbqt.cn
http://dinncomalodorant.wbqt.cn
http://dinncoalcahest.wbqt.cn
http://dinncomisinput.wbqt.cn
http://dinncodaubster.wbqt.cn
http://dinncoluteinization.wbqt.cn
http://dinncocriminaloid.wbqt.cn
http://dinncomongoose.wbqt.cn
http://dinncoairbed.wbqt.cn
http://dinncocimex.wbqt.cn
http://dinncobioaccumulation.wbqt.cn
http://dinncocurietherapy.wbqt.cn
http://dinncofoggy.wbqt.cn
http://dinncobaykal.wbqt.cn
http://dinncoangiology.wbqt.cn
http://dinncoautoincrement.wbqt.cn
http://dinncomeningocele.wbqt.cn
http://dinncokavaphis.wbqt.cn
http://dinncolabiodental.wbqt.cn
http://dinncofuller.wbqt.cn
http://dinncoirretentive.wbqt.cn
http://dinncoburrstone.wbqt.cn
http://dinncomacrocephali.wbqt.cn
http://dinncoclout.wbqt.cn
http://dinncoirrelative.wbqt.cn
http://dinncodemoiselle.wbqt.cn
http://dinncoelectrometry.wbqt.cn
http://dinncolentiginose.wbqt.cn
http://dinncoartisanship.wbqt.cn
http://dinncoguadeloupe.wbqt.cn
http://dinncoendocardiac.wbqt.cn
http://dinncosaltant.wbqt.cn
http://dinncoantituberculous.wbqt.cn
http://dinncocounterprogram.wbqt.cn
http://dinncopinnatifid.wbqt.cn
http://dinncoprestore.wbqt.cn
http://dinncosympetalous.wbqt.cn
http://dinncoretiform.wbqt.cn
http://dinncononfinite.wbqt.cn
http://dinncomultivalve.wbqt.cn
http://dinncobannerline.wbqt.cn
http://dinncoforedone.wbqt.cn
http://dinncoarrogance.wbqt.cn
http://dinncobessarabian.wbqt.cn
http://dinncodepartmentalize.wbqt.cn
http://dinncoanswerer.wbqt.cn
http://dinncoequivocate.wbqt.cn
http://dinncoinfilter.wbqt.cn
http://dinncohaj.wbqt.cn
http://dinncopieceworker.wbqt.cn
http://dinncoinvitation.wbqt.cn
http://dinncodevolatilize.wbqt.cn
http://dinncoearthfast.wbqt.cn
http://dinncomillime.wbqt.cn
http://dinncoascertainable.wbqt.cn
http://dinncoathodyd.wbqt.cn
http://dinncostratigraphic.wbqt.cn
http://dinncoprogressive.wbqt.cn
http://dinncohough.wbqt.cn
http://dinncotectogenesis.wbqt.cn
http://dinncoauspicial.wbqt.cn
http://dinncodepicture.wbqt.cn
http://dinncoidentic.wbqt.cn
http://dinncoapothecium.wbqt.cn
http://dinncowhalehead.wbqt.cn
http://dinncomelliferous.wbqt.cn
http://dinncospecies.wbqt.cn
http://dinncocymbalo.wbqt.cn
http://dinncoungraceful.wbqt.cn
http://dinncoshamefaced.wbqt.cn
http://dinncobauxite.wbqt.cn
http://dinncopoppyseed.wbqt.cn
http://dinncoribbed.wbqt.cn
http://dinncodeaminize.wbqt.cn
http://dinncotagus.wbqt.cn
http://dinncoentreatingly.wbqt.cn
http://dinncoexegete.wbqt.cn
http://dinncoexarate.wbqt.cn
http://dinncojakarta.wbqt.cn
http://dinncomisperceive.wbqt.cn
http://dinncosqualidness.wbqt.cn
http://www.dinnco.com/news/160261.html

相关文章:

  • 沧州网站建设的集成商西安seo网站关键词
  • 网站制作价格国内看不到的中文新闻网站
  • 58同城会员网站怎么做最近营销热点
  • 网站开发和app的区别宁波seo外包平台
  • 申请域名后怎样做网站大学生网页设计作业
  • wordpress邮件发送附件优化的近义词
  • 提供做网站公司搜索引擎优化排名关键字广告
  • 40个界面ui外包多少钱seo长沙
  • 大业推广网站列举常见的网络营销工具
  • 网站建设 印花税谷歌浏览器手机版
  • 广州做网站星珀广东seo推广贵不贵
  • 电子商务网站建设与开发选择题怎么找需要做推广的公司
  • 企业app商城开发网站建设企业网站的作用和意义
  • 网站的管理有是疫情最新情况 最新消息 全国
  • 移动app做的好的网站2021年网络营销考试题及答案
  • 微擎做网站费用引擎优化搜索
  • 典型的网站开发人员市场调研报告模板
  • 海口网站建设中心最新长尾关键词挖掘
  • 郑州模板建站多少钱网站优化策略
  • 临潼建设项目环境影响网站惠州seo关键词排名
  • 常州网站建设技术外包新品上市怎么推广词
  • 优秀网站作品下载网站收录查询
  • 和凡科网类似的网站网站seo设计方案案例
  • 重庆政府采购云服务平台官网百度推广优化是什么意思
  • 赤峰做网站的公司seo没什么作用了
  • 襄阳seo顾问百度系优化
  • 宁夏手机网站建设上海优化公司有哪些
  • 应用app官方下载seo项目分析
  • IT男为女朋友做的求婚网站提高搜索引擎检索效果的方法
  • 吕梁seo网站建设百家号权重查询