#include "pch.h"
#include<iostream>
using namespace std;
struct node
{
int data;
node * next;
};
class linkList
{
public:
linkList();
linkList(int a[], int n); //建立有n个元素的单链表
int length(); //得到单链表的长度
int locate(int x); //查找元素为x的下标
int get(int x); //查找下标为x的元素
void insert(int i, int x); //在第i个元素的位置插入x
int Delete(int i); //删除第i个元素
void printList(); //打印线性表,按序号依次遍历
~linkList();
private:
node * first; //头指针
};
//头插法
/*linkList::linkList(int a[], int n)
{
auto first = new node;
first->next = nullptr;
for (int i = 0; i != n; i++) {
auto s = new node;
s->data = a[i];
s->next = first->next;
first->next = s;
}
}*/
void LinkList::Reverse()
{
auto p = first;
auto q = p->next;
Node * r = nullptr;
first->next = nullptr;
while (q)
{
r = q->next;
q->next = p;
p = q;
q = r;
}
first = p;
}
反转链表的时候first指向了第二个结点,但是我觉得没有问题,是我哪里想错了?
单链表的一些操作,没有输出。不知道哪里错了!!!求大哥帮忙!
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- JRneymar 2019-03-16 14:41关注
linkList::linkList(int a[], int n) {
first = new node;
first->next = NULL;
auto r = first;
for (int i = 0; i < n; i++) {
auto s = new node;
s->data = a[i];
s->next = NULL;
// r是NULL
r->next = s; //把指向头结点的地址赋给下一个结点
r = s; //每插入一个结点都把该结点"当作"头结点
}
}
尾插法改成这样,原来定义一个局部的指针first,不会对类中的私有变量first进行初始化
locate函数中在 p = p->next;后面添加++cnt;计数器自增,不然查询到的数据的下表始终为1解决 无用评论 打赏 举报
悬赏问题
- ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
- ¥15 如何在scanpy上做差异基因和通路富集?
- ¥20 关于#硬件工程#的问题,请各位专家解答!
- ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
- ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
- ¥30 截图中的mathematics程序转换成matlab
- ¥15 动力学代码报错,维度不匹配
- ¥15 Power query添加列问题
- ¥50 Kubernetes&Fission&Eleasticsearch
- ¥15 報錯:Person is not mapped,如何解決?