基于类的链表类无相应构造函数报错

#include<bits/stdc++.h>
using namespace std;
const int MaxSize = 10;
template <class T>
class Seqlist {
public:
Seqlist() { length = 0;}
Seqlist(T [],int);
private:
int length;
T data[MaxSize];
};
class B {
public:
B(T);
B() {} //这个默认的构造函数十分重要
private:
T data;
};
B::B(T n) {
data = n;
} template <class T>
Seqlist<T>::Seqlist(T arr[], int n) {
if (n > MaxSize) throw "invalid num";
for (int i = 0;i < n;i++) {
data[i] = arr[i];
}
length = n;
} int main() {
B b[3] = {B(10), B(20), B(30)};
Seqlist<B> list(b,3);
}

在上面部分代码中,如果把有注释的那一行代码删去,则这部分代码不能正常运行,报错信息是

no matching function for call to 'B::B()'[25, 35]

根据这个报错信息找到相应行数,居然在int n这里报错,我寻思着这关n什么事,后面查阅了资料,原因出在第34行的B b[3]这里,定义了一个B类型的数组,没有参数传入,而B类中无适配该成员的构造函数,于是编译器报错

解决方法是,加上相应的构造函数B() {}

线性链表的反转和复制功能

#include<bits/stdc++.h>
using namespace std;
template <class T>
struct Node {
T data;
Node<T>* next;
}; template <class T>
class LinkList {
public:
LinkList(); // create an empty list
LinkList(T[], int);
//~LinkList(); void Reverse(Node<T>* head);
Node<T>* Copy(Node<T>* head);
Node<T>* first;
} template <class T>
LinkList<T>::LinkList() {
first = new Node<T>;
first->next = NULL;
} template <class T>
LinkList<T>::LinkList(T arr[], int n) {
first = new Node<T>;
Node<T>* p = first;
for (int i = 0;i < n;i++) {
Node<T>* s = new Node<T>;
s->data = arr[i];
p->next = s;//让first指向第一个节点
p = s;//虽说把s的地址赋给p,但是first的地址和p不一样,对p操作不会改变first
//因此first永远指向链表第一个位置
}
p->next = NULL;
} template <class T>
void LinkList<T>::Reverse(Node<T>* head) {
Node<T>* pre, *cur;
cur = head->next;
head->next = NULL;
while (cur) {
pre = cur;//让当前节点的上一节点移动到当前节点位置
cur = cur->next;//当前节点移动到下一个位置
pre->next = head->next;//这一操作就是让pre不断指向前一个节点
head->next = pre;//更新节点,让head的next指向pre
}
//在画图理解时,要让cur和pre同时向后移动
//这一部分,建议自己在纸上画出若干个节点和用三个小部件(代表三个指针)模拟一边才能够真正地理解
}
//复盘时自己有个小细节没注意到,这里都是指针变量的赋值操作,这里的赋值只是赋予地址,给予者的值改变,接收者的值不会改变 template <class T>
Node<T>* LinkList<T>::Copy(Node<T>* head) {
Node<T>* headB = new Node<T>;
Node<T>* pb = headB;
Node<T>* pa = head->next;
while (pa != NULL) {
Node<T>* temp = new Node<T>;
temp->data = pa->data;
temp->next = NULL;//这里用到了一个临时指针变量
pb->next = temp;//让pb连上temp
pb = pb->next;
pa = pa->next;
//这里向后移动
}
return headB;
//注意这里返回的是headB,在调用时记得再加一个"->next"
} int main() {
int arr[] = {1, 2, 3, 4, 5};
LinkList<int> list(arr,5);
cout << "the origin state: " << endl;
list.PrintList(); cout << endl << "copy list a to list b\n";
Node<int>* ptr = new Node<int>;
ptr = list.copy(list.first)->next;
while (ptr != NULL) {
cout << ptr->data << ' ';
ptr = ptr->next;
} cout << endl << "reverse the list a\n";
list.Reverse(list.first);
list.PrintList();
}

链表反转参考视频

LeetCode力扣刷题 | 剑指Offer 24. 反转链表_哔哩哔哩_bilibili [小姐姐声音很温柔doge]

一分钟教你链表反转_哔哩哔哩_bilibili [这个动画模拟比较贴合代码框的函数]

//谁知道我当时居然还去断点debug把每个节点以及他们的next的地址抄下来去对比

原文出处:Jayden's Blog--数据结构--关于单链表小细节的一些补充

数据结构(C++)--学习单链表时发现的一些小坑的更多相关文章

  1. 数据结构学习--单链表(python)

    概念 链表(linked_list)是物理存储单元上非连续的.非顺序的存储结构,数据元素的逻辑顺序 是通过链表的指针地址实现,每个元素包含两个结点,一个是存储元素的数据域 (内存空间) ,另一个是指向 ...

  2. 数据结构——Java实现单链表

    一.分析 单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素.链表中的数据是以结点来表示的,每个结点由元素和指针构成.在Java中,我们可以将单链表定义成一个类,单链表的基 ...

  3. PHP数据结构之实现单链表

    学习PHP中,学习完语法,开始尝试实现数据结构,今天实现单链表 <?php class node //节点的数据结构 { public $id; public $name; public $ne ...

  4. js数据结构与算法--单链表的实现与应用思考

    链表是动态的数据结构,它的每个元素由一个存储元素本身的节点和一个指向下一个元素的引用(也称指针或链接)组成. 现实中,有一些链表的例子. 第一个就是寻宝的游戏.你有一条线索,这条线索是指向寻找下一条线 ...

  5. C++学习---单链表的构建及操作

    #include <iostream> using namespace std; typedef struct LinkNode { int elem;//节点中的数据 struct Li ...

  6. 数据结构:DHUOJ 单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果)

    单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果) 时间限制: 1S类别: DS:线性表->线性表应用 题目描述: 输入范例: -5345646757684654765867 ...

  7. 数据结构-多级指针单链表(C语言)

    偶尔看到大一时候写了一个多级链表,听起来好有趣,稍微整理一下. 稍微注意一下两点: 1.指针是一个地址,他自己也是有一个地址.一级指针(带一个*号)表示一级地址,他自身地址为二级地址.二级指针(带两个 ...

  8. TZOJ 数据结构实验:单链表元素插入

    描述 实现函数CreateHeader用于创建空链表,实现Insert函数并调用它完成带头节点链表的创建. 部分代码已经给出,请补充完整,提交时请勿包含已经给出的代码. void PrintLinkL ...

  9. 使用MyBatis框架时发现的一些小bug

    在大配置MyBatis.xml中:  不能有空节点属性 ,否则启动服务器后点击登录没有反应. 异常问题: ause: java.sql.SQLException: Value '0000-00-00 ...

  10. 数据结构(java版)学习笔记(三)——线性表之单链表

    单链表的优点: 长度不固定,可以任意增删. 单链表的缺点: 存储密度小,因为每个数据元素,都需要额外存储一个指向下一元素的指针(双链表则需要两个指针). 要访问特定元素,只能从链表头开始,遍历到该元素 ...

随机推荐

  1. HarmonyOS SDK开放能力,服务鸿蒙生态建设,打造优质应用体验

    华为开发者大会2023(HDC.Together)于8月4日至6日在东莞松山湖举行,在HarmonyOS端云开放能力技术分论坛上,华为为广大开发者们介绍了HarmonyOS SDK开放能力在基础开发架 ...

  2. Hypium框架使能ArkTS应用高效测试

     原文链接:https://mp.weixin.qq.com/s/Ncc-x_4zy4wBZmSjknw1lQ,点击链接查看更多技术内容:   HarmonyOS发布了声明式开发框架ArkUI,带来了 ...

  3. Linux之Docker搭建KMS服务器

    前言 在大规模软件部署和管理的过程中,激活授权管理是一项至关重要的任务.微软的KMS(Key Management Service)是一个广泛使用的技术,它使得大型组织能够在本地网络内集中管理Wind ...

  4. 一种新的姿势:程序try/catch抛出异常之绕过canary pwn121

    一种新的姿势:程序try/catch抛出异常之绕过canary 我前面发了不少关于绕过canary的姿势,先总结一下,现在绕过canary的姿势有泄露,爆破,格式化字符串绕过,多线程劫持TLS绕过, ...

  5. redis 简单整理——bitmaps[十二]

    前言 简单介绍一下bitmaps这个东西. 正文 我们都知道bitmaps 翻译过来就是二进制. 那么二进制可以存一些什么呢? 图片.视频,还可也存些什么呢? 现代计算机用二进制(位)作为信息的基础单 ...

  6. Vue 数据更新但页面没有更新的 7 种情况,你遇到过几种

    1. Vue 无法检测实例被创建时不存在于 data 中的 property 原因:由于 Vue 会在初始化实例时对 property 执行 getter/setter 转化,所以 property ...

  7. EventBridge 特性介绍|以 IaC 的方式使用 EventBridge

    ​简介:本文将重点介绍 EventBridge 和 IaC 的重点概念和特性,然后演示如何应用 IaC 理念自动化部署 EventBridge 来使用这些概念和特性. 作者:王川(弗丁) 引言 Eve ...

  8. 这是阿里技术专家对 SRE 和稳定性保障的理解

    简介: 在技术工作中,对于产品/基础技术研发和 SRE 两种角色,通常会有基于「是否侧重编码」的理解.对于产品研发转做 SRE ,经常会产生是否要「脱离编码工作」的看法,或者认为是否要「偏离对产品/基 ...

  9. [GPT] vue 的 quasar 框架 在 layout 模版中 如何获取 子页面当前使用的 useMeta

      在 Quasar 框架中,用 Vue Router 的 meta 字段来获取子页面当前使用的 useMeta . 首先,您需要在路由配置中设置子页面的 meta 字段.例如: const rout ...

  10. Python:Short Circuiting -- “OR”

    Short Circuiting Operator Checks if: Evaluates from left to right up to: Example AND All values are ...