跟着青岛大学-王卓老师的视频进行到链队列时,运行链队列代码的时候遇到了两个问题:

1.)Program received signal SIGSEGV Segmentation fault

附代码:

 #include<stdio.h>
 #include<stdlib.h>
 typedef char  ElemType;
 typedef struct qnode{
  ElemType data;
  struct qnode *next;
 }DataNode; //数据节点
 typedef struct{
  DataNode *front;
  DataNode *rear;
 }LinkQuNode; //链队节点
 //初始化
 void InitQueue(LinkQuNode *&q){
 ​
  q = (LinkQuNode *)malloc(sizeof(LinkQuNode)); //必加
  q->front = q->rear = (DataNode *)malloc(sizeof(DataNode));
  q->front->next = NULL;
 }
 ​
 //判断是否为空
 bool EmptyQueue(LinkQuNode *q){
  if(q->front->next == NULL) return true;
  return false;
 }
 //入队
 void EnQueue(LinkQuNode *&q,ElemType e){
  DataNode *p;
  p = (DataNode *)malloc(sizeof(DataNode));
  p->data = e;
  p->next = NULL;
  q->rear->next = p;
  q->rear = p;
 }
 //出队
 bool DeQueue(LinkQuNode *&q,ElemType &e){
  if (EmptyQueue(q)) return false;
  DataNode *p;
  p = q->front->next;
  e = p->data;
  q->front->next = p->next;
  free(p);
 // printf("%c\n",e);
  return true;
 }
 int main(){
  LinkQuNode *p;
  ElemType a[]="abcdefg",b[10]="";
  InitQueue(p);
 }

分析及解决:调用InitQueue函数的时候有用到q指针 但是却没有给他赋初始值;加上代码q = (LinkQuNode *)malloc(sizeof(LinkQuNode)); 后问题解决;

2.) 出队一直死循环 运行没有结果;

 //出队
 bool DeQueue(LinkQuNode *&q,ElemType &e){
  if (q->front == q->rear) return false;
  DataNode *p;
  p = q->front->next;
  e = p->data;
  q->front->next = p->next;
  free(p);
 // printf("%c\n",e);
  return true;
 }
 int main(){
  LinkQuNode *p;
  ElemType a[]="abcdefg",b[10]="";
 ​
  InitQueue(p);
 
  for(int i=0;i<=strlen(a);i++) EnQueue(p,a[i]);//入队
  for(int i=0;DeQueue(p,b[i]);i++); //出队
  printf("%s",b);
 }

分析及解决: 想了很久,但是一直没有找出来, 这玩意果然还是得动手用笔画一下,一画思路就清晰了,可以看到在进行出队操作的时候,front其实一直都没有动,所有的操作都是改变front->next的值,如果判断条件为 q->front == q->rear 那么它一直都走不出来

冷静换个思路想 末尾元素是g,而它的next是指向NULL,那么当front走到g元素的位置,用front->next==NULL 就可以确定此时链队列已经没有元素了,将第3行改为if(q->front->next == NULL) return false; 错误解决

这是小弟第一次写博客笔记,上面只是个人的一些理解,有什么不对的地方欢迎大家批评指正,谢谢!

 

《数据结构》王卓老师 p48-p62学习反馈的更多相关文章

  1. 郝斌老师C语言学习笔记(一)

    在给变量分配内存时,很可能这段内存存在以前其他程序使用留下的值.当使用VC编译器,若编译器发现没有给变量赋值而使用,就会返回一个以“85”开头的很大的数字(此时该段内存中为一个垃圾数,为了避免出现较常 ...

  2. 20172328 2018-2019《Java软件结构与数据结构》第六周学习总结

    20172328 2018-2019<Java软件结构与数据结构>第六周学习总结 概述 Generalization 本周学习了第十章:非线性集合与数据结构--树.主要讨论了树的使用和实现 ...

  3. 20172328 2018-2019《Java软件结构与数据结构》第七周学习总结

    20172328 2018-2019<Java软件结构与数据结构>第七周学习总结 概述 Generalization 本周学习了第11章:二叉查找树.在本章中,主要探讨了二叉查找树的概念和 ...

  4. 20172306 2018-2019-2 《Java程序设计与数据结构》第八周学习总结

    20172306 2018-2019-2 <Java程序设计与数据结构>第八周学习总结 教材学习内容总结 堆 堆是具有两个附加属性的一棵二叉树 它是一个完全树 对每一结点,它小于或等于其左 ...

  5. 20172306 2018-2019-2 《Java程序设计与数据结构》第七周学习总结

    20172306 2018-2019-2 <Java程序设计与数据结构>第七周学习总结 教材学习内容总结 概述 二叉查找树是一种含有附加属性的二叉树,即其左孩子小于父结点,而父结点又小于或 ...

  6. 20172306 2018-2019-2 《Java程序设计与数据结构》第六周学习总结

    20172306 2018-2019-2 <Java程序设计与数据结构>第六周学习总结 教材学习内容总结 概述(了解一下树的一些概念) 树是一种非线性结构.树由一个包含结点和边的集构成,其 ...

  7. 2018-2019-20172329 《Java软件结构与数据结构》第五周学习总结

    2018-2019-20172329 <Java软件结构与数据结构>第五周学习总结 教材学习内容总结 <Java软件结构与数据结构>第九章-排序与查找 一.查找 1.查找概念简 ...

  8. 2018-2019-20172329 《Java软件结构与数据结构》第八周学习总结

    2018-2019-20172329 <Java软件结构与数据结构>第八周学习总结 现在对于我而言,最珍贵的是时间,感觉自己在时间飞逝的时候真的挽留不住什么,只能怒发冲冠的让自己疯狂的学习 ...

  9. 2018-2019-20172329 《Java软件结构与数据结构》第六周学习总结

    2018-2019-20172329 <Java软件结构与数据结构>第六周学习总结 学无止境,希望自己可以坚持下去,就算自己有太多的事情也不希望自己落下学习,也希望自己可以活成自己想要的样 ...

  10. 2018-2019-20172321 《Java软件结构与数据结构》第八周学习总结

    2018-2019-20172321 <Java软件结构与数据结构>第八周学习总结 教材学习内容总结 第12章 优先队列与堆 一.概述 堆 堆的前提就是他首先是一个完全二叉树,其次就是满足 ...

随机推荐

  1. Electron App 安装包定制 -- Inno Setup 脚本 Pascal Scripting 初探

    在做 Electron 项目时,有个需求是安装包安装时要给客户机上装上某个软件 在查看 Inno Setup 官网后发现是通过 .iss 脚本编写实现自定义安装过程 可在 .iss 内可以添加脚本为安 ...

  2. 从数据库中读取数据并写入到Excle电子表格之1

    //获取数据 using (SqlDataReader reader = Alian_SQL_Helper.SQL_Helper .ExecuteReader( "select CC_Aut ...

  3. List子集合__小记

    List集合的子实现类的特点: ArrayList: 底层数据结构是数组的形式,满足数组结构的特点:查询快,增删慢 从线程安全问题来看:线程不安全的,不同步,执行效率高 Vector: 底层数据结构是 ...

  4. 如何将Maven项目快速改造成一个java web项目(方式一)

    因为实际需要,需要将一个maven项目改造成原生的java-web项目,写这边博客 来记录整个改造的过程.原始的maven项目,使用IDEA打开后,目录结构如下所示 直接通过文件夹查看项目结果如下 首 ...

  5. SEO相关配置 HTML meta标签总结与属性使用介绍

    HTML meta标签总结与属性使用介绍 <!-- 声明文档使用的字符编码 --> <meta charset='utf-8'> <!-- 优先使用 IE 最新版本和 C ...

  6. #Powerbi 1分钟学会利用AI,为powerbi报表进行高端颜色设计

    在BI报表的设计中,配色方案往往成为一大难题,一组切合主题.搭配合理的颜色设计往往能为我们的报表,加分不少. 今天,就介绍一个AI配色的网站,利用AI为pbi报表进行配色设计. 一:网站网址 http ...

  7. spring-mvc 系列:视图(ThymeleafView、InternalResourceView、RedirectView)

    目录 一.ThymeleafView 二.转发视图 三.重定向视图 四.视图控制器view-controller 五.配置jsp解析 SpringMVC中的视图是View接口,视图的作用渲染数据,将模 ...

  8. java file I/O流

    一.File的简介:(java.io包) 生活中的文件: (1)文件的作用:持久化(瞬时状态的对立面状态) (1)文件的定义:一堆数据的集合 (2)文件存储的位置:磁盘,硬盘,软盘,U盘等等 计算机中 ...

  9. Spring面试攻略:如何展现你对Spring的深入理解

    什么是Spring?谈谈你对IOC和AOP的理解. Spring是一种Java开发框架,旨在简化企业级应用程序的开发和部署.它具有以下优点: 对象托管:Spring能够管理和赋值所有对象,使开发人员不 ...

  10. C++函数参数匹配规则

    C++ 函数参数匹配 1 单个参数匹配 void f(); //f1 void f(int); //f2 void f(int, int); //f3 void f(double, double=3. ...