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

专业做网站的人开封搜索引擎优化

专业做网站的人,开封搜索引擎优化,徐州网站优化,城市门户网站策划书浅谈链表的优化技巧 麻烦写法: 正常写链表,都是一个头元素 head 一个尾元素 tail 来记录链表的虚拟头和虚拟尾或真实头和真实尾。 但是显然在插入操作和删除操作的时候,这种写法就会显得很麻烦,要特判一大堆情况: …

浅谈链表的优化技巧

麻烦写法:

正常写链表,都是一个头元素 head 一个尾元素 tail 来记录链表的虚拟头和虚拟尾或真实头和真实尾。

但是显然在插入操作和删除操作的时候,这种写法就会显得很麻烦,要特判一大堆情况:

  • 插入的元素在链表头:更新 head 且只要更新两条关系链。
  • 在中间:最正常,没话说,需更新四条关系链:pre → \rightarrow cur & cur → \rightarrow pre & cur → \rightarrow nxt & nxt → \rightarrow pre。
  • 在末尾:更新 tail 且只要更新两条。

给个代码:

	void Insert(int i,char ch){++tot;node[tot].ch=ch;if(!h)h=t=tot;else{if(!i){node[tot].nxt=h,node[h].pre=tot;h=tot;}else{int x=Find(i),y=node[x].nxt;node[tot].pre=x;node[tot].nxt=y;if(!y)t=tot;elsenode[y].pre=tot;node[x].nxt=tot;}}++m;return;}void del(int i){if(m==1)h=t=0;else{if(i==1){h=node[h].nxt;node[h].pre=0;}else{if(i==m){t=node[t].pre;node[t].nxt=0;}else{int x=Find(i);int l=node[x].pre,r=node[x].nxt;node[r].pre=l;node[l].nxt=r;}}}--m;return;}

看着就很头疼啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊。。。

怎么说。。细节太多了,不好搞。码量大,还容易炸。

优化方法:

为链表添加虚拟的头尾元素。使得真正的链表只在虚拟头之后、虚拟尾之前。

  • 初始化时添加,所以链表至少有两个元素
  • 操作时不会涉及到虚拟元素,所以可以避免操作链表头尾

怎么样,看着就挺 nice 的。

操作事项:

  • 虚拟头的后面就是真正头
  • 虚拟尾的后面就是真正尾
  • 虚拟头的靠后元素为虚拟尾时,实际链表为空链表

别急——此时还能优化!

有种链表叫做环形链表,即 node[tail].nxt=headnode[head].pre=tail

那么我们就不用用两个虚拟元素,用一个虚拟元素将链表连成环形

  • 只需要一个虚拟元素,环形链表没有链表头和链表尾
  • 操作时不会涉及到虚拟元素,所以链表不可能是空链表
  • 虚拟元素的靠后元素就是真实头
  • 虚拟元素的考前元素就是实际尾
  • 虚拟元素的靠后元素为自己时,实际链表为空

好处呢?

通常用下标为 0 0 0 的元素作为虚拟元素(造福了数组模拟链表党)

  • 空指针也用 0 0 0 表示
  • 可以访问下标为 0 0 0 的元素,但是不能访问空指针

这时候懒得打代码怎么办?

Copy 一下老师的代码

void Insert(int i, char c) {      // 第 i 个字符后插入 ce[++n] = {c};                   // 新插入的元素int x = Find(i), y = e[x].nxt;  // 找到插入位置 xe[n].prv = x, e[n].nxt = y;     // 新元素 n 与两边建立联系e[y].prv = e[x].nxt = n;++m;
}void Delete(int i) {int x = Find(i), l = e[x].prv, r = e[x].nxt;e[r].prv = l, e[l].nxt = r;m--;
}

是不是瞬间清洗许多?

撒花~~

http://www.dtcms.com/wzjs/37643.html

相关文章:

  • 哈尔滨网站设计报价百度查询网
  • 维护网站需要多少钱武汉网站营销seo方案
  • 网站首页轮播图片素材国内免费发布产品的平台
  • 怎么样建设一个电影网站视频下载seo网络推广到底是做什么的
  • 手机门户WordPress主题windows11优化大师
  • 网站开发 与 网页设计的区别软文范例大全800字
  • 推广的网站有哪些全渠道营销
  • 上饶专业企业网站建设谷歌seo博客
  • 湖南网站建设公司谷歌搜索引擎为什么打不开
  • 建设银行嘉兴分行网站首页it培训学校哪家好
  • 西安哪里可以做公司网站免费网站在线客服软件
  • 建设公司网站费用怎么做账如何让自己的网站排名靠前
  • 免费制作自己的网站长产品品牌策划方案
  • 新的龙岗网站建设手机免费建网站
  • 做视频赚钱的网站有哪些百度账号登录不了
  • 政府网站建设赏析在线外链推广
  • 自己做壁纸的网站百度seo关键词排名价格
  • 做食品网站需要什么资质曼联vs曼联直播
  • 看男女做那个视频网站seo排名优化培训
  • 做网站那里做可靠深圳网络推广专员
  • 公交公司网站建设的意义南宁排名seo公司
  • 金属网站模板谷歌商店下载官方
  • 临沂哪里有做网站关键词优化包年推广
  • wordpress 去除html处理器优化软件
  • 企业网站管理系统站长之家android优化大师
  • 为什么用php做网站营销策略理论
  • 手机维护 Wordpress信息流优化师是做什么的
  • 科技让生活更美好500字六年级seo销售代表招聘
  • 如何使用wp做网站江苏seo排名
  • 会ps的如何做网站免费涨1000粉丝网站