- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要使用模板构建链表,但我不知道为什么不起作用,我以前构建过链表,但从未使用模板。现在我的问题是,如果我创建列表,一切正常,但是当我尝试向其中插入内容时,出现以下错误:
Error C2664 'Nodo<D>::Nodo(Nodo<D> &&)': cannot convert argument 1 from 'const int' to 'const Nodo<D> &' Datos2 d:\google drive\visual studio 2015\projects\datos2\datos2\listaSimple.h 69
Error C2664 'Nodo<D>::Nodo(Nodo<D> &&)': cannot convert argument 1 from 'const int' to 'const Nodo<D> &' Datos2 d:\google drive\visual studio 2015\projects\datos2\datos2\listaSimple.h 73
使用我的以下代码:
//linkedList.h
#pragma once
#ifndef _LISTASIMPLE_H
#define _LISTASIMPLE_H
template<class D>
struct Nodo
{
int carga;
int binario;
D caracter;
Nodo<D> *Siguiente;//means next
};
template<class D>
class listaSimple
{
public:
listaSimple();
~listaSimple();
void InsertarInicio(const D&);
bool ListaVacia();
void Mostrar();
private:
Nodo<D> *primero;
Nodo<D> *ultimo;
};
template<class D>
listaSimple<D>::listaSimple()
{
primero = NULL;
}
template<class D>
listaSimple<D>::~listaSimple()
{
Nodo<D> *aux;
while (primero != NULL)
{
aux = primero;
primero = primero->Siguiente;
delete aux;
}
}
template<class D>
void listaSimple<D>::InsertarInicio(const D& dato)
{
if (ListaVacia())
{
primero = new Nodo<D>(dato);
}
else
{
Nodo<D> *nodoNuevo = new Nodo<D>(dato);
nodoNuevo->Siguiente = primero;
primero = nodoNuevo;
}
}
template<class D>
bool listaSimple<D>::ListaVacia()
{
if (primero == NULL)
{
return true;
}
else
{
return false;
}
}
template<class D>
inline
void listaSimple<D>::Mostrar()
{
Nodo<D> *aux = primero;
while (aux != NULL)
{
cout << aux->caracter << "->";
aux = aux->Siguiente;
}
}
和
//Source.cpp
#include <iostream>
#include <string>
#include "linkedList.h"
using namespace std;
int main() {
listaSimple<int> Nueva;
Nueva.InsertarInicio(5);
system("pause");
return 0;
}
最佳答案
请参阅 Node
的更正版本和 linkedList
.注意 Node
和 linkedList
不包含有关实际数据的任何信息。事实上,您可以在最后声明数据 ( struct MyData
)。
为了打印,我添加了一个函数:
node->data.print();
这边Node
和 linkedList
不直接负责打印数据,他们不需要了解数据的任何信息。他们可以问DataType
打印数据。 DataType
必须包含 print
打印自己的内容的功能。
template<typename DataType>
struct Node
{
DataType data;
Node<DataType> *Next;
Node()
{
Next = nullptr;
}
};
template<typename DataType>
class linkedList
{
public:
linkedList()
{
first = NULL;
}
~linkedList()
{
Node<DataType> *aux;
while (first != NULL)
{
aux = first;
first = first->Next;
delete aux;
}
}
void InsertBegining(const DataType& data)
{
Node<DataType> *newNode = new Node<DataType>;
newNode->data = data;
if (first)
{
newNode->Next = first;
first = newNode;
}
first = newNode; //<== you forgot this
}
void Print()
{
Node<DataType> *walk = first;
while (walk)
{
walk->data.print();
walk = walk->Next;
}
}
private:
Node<DataType> *first;
};
现在你可以声明MyData
并使用它。确保 MyData
包括 print
功能。还有 MyData
由于分配数据的方式,必须是 POD(普通旧数据,它不能包含指针)。
int main()
{
struct MyData
{
int charge;
int binario;
char ch;
void print()
{
cout << charge << ", " << binario << ", " << ch << "\n";
}
};
linkedList<MyData> list;
MyData data;
data.binario = 1;
data.ch = 'A';
data.charge = 10;
list.InsertBegining(data);
data.binario = 2;
data.ch = 'B';
data.charge = 20;
list.InsertBegining(data);
list.Print();
system("pause");
return 0;
}
另一种方法:
您可以添加 <<
MyData
的运算符重载
struct MyData
{
int charge;
int binario;
char ch;
friend std::ostream& operator<< (std::ostream &out, MyData &x)
{
out << x.ch << ", " << x.binario << ", " << x.charge;
return out;
}
};
所以 MyData
知道如何打印自己。示例:
MyData data;
data.ch = 'A';
data.binario = 1;
data.charge = 10;
cout << data << "\n";
这应该打印 "A, 1, 10"
.
然后你可以改变linkList::Print()
到
...
void Print()
{
Node<DataType> *walk = first;
while (walk)
{
std::cout << walk->data << "\n";
walk = walk->Next;
}
}
现在linkedList
独立于MyData
只要MyData
有<<
运算符重载(其数据为 POD)。您还可以将此链表用于基本类型。示例:
linkedList<int> test;
test.InsertBegining(1);
test.InsertBegining(2);
test.Print();
关于c++ - 带模板的链表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40443721/
运行 PostgreSQL(7.4 和 8.x),我认为这是可行的,但现在我遇到了错误。 我可以单独运行查询,它工作得很好,但如果我使用 UNION 或 UNION ALL,它会抛出错误。 这个错误:
我试图为我的应用程序创建一个导航,使用抽屉导航我的 fragment 之一(HomeFragment)有一个 ViewPager,可容纳 3 个 fragment (Bundy Clock、Annou
以我目前正在开发的应用为例: - 它有一个包含多个项目的抽屉导航;现在有两个项目让我感兴趣,我将它们称为 X 和 Y。 X 和 Y 都在单击时显示包含 x 元素或 y 元素列表的 fragment 选
我有一个形状为 (370,275,210) 的 NumPy 数组,我想将其重新整形为 (275,210,370)。我将如何在 Python 中实现这一点? 370是波段数,275是行数,210是图像包
我们如何与被子 UIViewController 阻止的父 UIViewController(具有按钮)交互。显然,触摸事件不会通过子 Nib 。 (启用用户交互) 注意:我正在加载默认和自定义 NI
我是 Jpa 新手,我想执行过程 我的代码如下 private static final String PERSISTENCE_UNIT_NAME = "todos"; private static
与安装了 LAMP 的 GCE 相比,选择与 Google Cloud SQL 链接的 GCE 实例有哪些优势? 我确定 GCE 是可扩展的,但是安装在其上的 mysql 数据库的可扩展性如何? 使用
这个问题在这里已经有了答案: Value receiver vs. pointer receiver (3 个答案) 关闭 3 年前。 我刚接触 golang。只是想了解为 Calc 类型声明的两种
我不小心按了一个快捷键,一个非常漂亮的断线出现在日期上。 有点像 # 23 Jun 2010 -------------------- 有人知道有问题的快捷方式吗?? (我在 mac 上工作!) 在
我正在Scala中编写正则表达式 val regex = "^foo.*$".r 这很好,但是如果我想做 var x = "foo" val regex = s"""^$x.*$""".r 现在我们有
以下 XML 文档在技术上是否相同? James Dean 19 和: James Dean 19 最佳答案 这两个文档在语义上是相同的。在 X
我在对数据帧列表运行稳健的线性回归模型(使用 MASS 库中的 rlm)时遇到问题。 可重现的示例: var1 <- c(1:100) var2 <- var1*var1 df1 <- data.f
好的,我有一个自定义数字键盘,可以在标签(numberField)中将数字显示为 0.00,现在我需要它显示 $0.00。 NSString *digit = sender.currentTitle;
在基于文档的应用程序中,使用 XIB 文件,创建新窗口时其行为是: 根据最后一个事件的位置进行定位和调整大小 window 。 如果最后一个事件窗口仍然可见,则新窗口 窗口应该是级联的,这样它就不会直
我想使用参数进行查询,如下所示: SELECT * FROM MATABLE WHERE MT_ID IN (368134, 181956) 所以我考虑一下 SELECT * FROM MATABLE
我遇到一些性能问题。 我有一个大约有 200 万行的表。 CREATE TABLE [dbo].[M8]( [M8_ID] [int] IDENTITY(1,1) NOT NULL,
我在 jquery 中的按键功能遇到问题。我不知道为什么按键功能不起作用。我已经使用了正确的 key 代码。在我的函数中有 2 个代码,其中包含 2 个事件键,按一个键表示 (+) 代码 107 和(
我想显示音频波形,我得到了此代码,它需要.raw音频输入并显示音频波形,但是当我放入.3gp,.mp3音频时,我得到白噪声,有人可以帮助我如何使其按需与.3gp一起使用使用.3gp音频运行它。 Inp
我无法让 stristr 函数返回真值,我相信这是因为我的搜索中有一个 $ 字符。 当我这样做时: var_dump($nopricecart); 完整的 $nopricecart 值是 $0 ,我得
如果我有这样的循环: for(int i=0;i O(n) 次。所以do some执行了O(n)次。如果做某事是线性时间,那么代码片段的复杂度是O(n^2)。 关于algorithm - 带 If 语
我是一名优秀的程序员,十分优秀!