- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试为我的结构写一个复制构造函数,但我似乎没有做对,如果有任何帮助,我将不胜感激。我想递归地做一个深拷贝,但我一直在收到初始化列表中的初始化建议,而且似乎也不太奏效。
struct Node
{
Node* left; // will be our previous
Node* right;// will be our next
Node* previous;// get a handle to the previous node
string value;
Node(string nval): left(NULL), right(NULL), previous(NULL), value(nval)
{
}
Node(Node const& node)
: previous(new Node(node.previous)),
left(new Node(node.left)),
right(new Node(node.right)),
value(node.value)
{
}
Node& operator=(const Node&)
{
// ...
}
};
提前致谢。
最佳答案
为避免这种无限递归,您需要测试 null。您还需要取消引用 RHS 节点中的对象。
Node(Node const& node) :
previous(node.previous ? new Node(*node.previous) : NULL),
left(node.left ? new Node(*node.left) : NULL),
right(node.right ? new Node(*node.right) : NULL),
value(node.value)
{
}
但这只有在 previous != next != previous
始终成立并且您的节点不指向彼此的情况下才有效。如果这是一个链表结构,这将不起作用。
我猜你的节点确实指向一起,而你在这里试图做的是在复制一个节点时克隆整个数据结构。在那种情况下,我看不到您可以在复制构造函数中明智地执行此操作的方法。我建议使类不可复制并编写一个单独的函数来克隆整个数据结构。如果您提供有关如何构建 Node
结构的更多上下文,我可能会提供更具体的建议。
编辑
您在注释中指出这是一棵树,previous
是父节点指针。这个复制构造函数应该做一个子树克隆:
Node(Node const& node) :
previous(NULL),
left(node.left ? new Node(*node.left) : NULL),
right(node.right ? new Node(*node.right) : NULL),
value(node.value)
{
if (left)
left->previous = this;
if (right)
right->previous = this;
}
请注意,它不会为 previous
分配新的 Node
,而是将其留空并让其父级设置它。
关于c++ - 在 C++ 中与复制构造函数作斗争,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10161072/
我想在 64 位数字中设置各个位,并认为 uint64_t是这份工作的理想选择。我遇到了一些奇怪的问题,所以我做了一些实验: 我写了下面的测试程序: #include #include #incl
所以我知道 mapply 将按元素顺序遍历一个数组(或一系列数组)——我想知道是否有办法阻止它对某些参数执行此操作……。让我进一步解释 我有一组数据点,带有 X 和 Y 坐标……X1 X2 ……Xn
我是 android 编程的新手,我正在尝试创建一个好友列表类。 首先,我创建了一个从数据库加载对象的数组: friendArray = new Friend[NumberOfFriendsInDat
我目前正在开发一个应用程序,该应用程序定期(每 30 秒)使用 json 格式从两个指定的足球队获取英国境内的两条推文。在 json 文件中,我可以访问当前文本的每条推文的位置(曼彻斯特、布里斯托尔等
我正在尝试编写一些 javascript 来询问用户,当他们离开页面时,是否要填写调查(无论这可能多么烦人!)。我认为我的解决方案是通过此站点上的答案找到的。这是我目前拥有的代码,但似乎无法正常工作:
好吧,我有一些关于使用拆分 Pane 将我的框架分成两个区域的技巧,但我无法让它显示一些有用的东西。代码如下所示: public class Whiteboard extends JPanel { i
我在 mod_rewrite htaccess 上苦苦挣扎了至少几天,但仍然无法解决这个问题。 我想在我的网站上强制使用 HTTPS SSL,但仅限于网络外部。 我有这样的东西: RewriteCon
我有一个非常简单的 XML 文件,需要用 xmlstarlet 解析(我在 Windows 下): IDENTIFYER 2013-01-25T11:15:
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 2年前关闭。 Improve t
我真的很努力地处理类、扩展和实现。 在 android 中,我想创建一个首选项屏幕并检查用户输入。 因此,我可以使用名为preferences.class的文件,并使用以下类执行我需要的所有操作:
我正在尝试运行 hello world boost python example乍一看一切都很好。我得到以下输出 >bjam ...patience... ...patience... ...foun
抱歉打扰大家了,这让我很痛苦。这是代码: char buf[500]; sprintf(buf,"D:\\Important\\Calibration\\Results\\model_%i.xml",
我最近了解了在 C++ 中使用反向迭代器的正确方法(特别是当您需要删除一个时)。 (参见 this question 和 this one。) 你应该这样做: typedef std::vector
我在使用 flex-layout 时遇到了一些问题。 我的代码通常如下所示: 我希望第二个 flex d
我遇到一个问题,一个简单的函数在到达 std::cin 请求时似乎终止了。编译器不会抛出任何警告或错误,也不会发生运行时错误,程序只会返回到主菜单。 片段: #include #include u
好的,希望这对您来说应该很容易。我是 git、BitBucket 的新手,也是版本控制的新手,我会遗漏一些对您来说很明显的东西。 所以这就是我所做的:我在我的机器上安装了 git 并设置了我的全局变量
我正在处理一个需要高度自动化的 Oracle 过程,因此我正在使用动态 SQL。我刚开始使用动态 SQL。 我正在使用 varchar2 变量来构建需要执行的 SQL。我使用了 dbms_output
我正在学习 python 和 Kivy,并且我真的很难理解如何从 Kivy GUI 调用函数和继续函数。 这是我的.py: import csv import os import easygui im
我试图在 WebView 中显示一个用 LaTex 编写的数学公式,但我在字符“\”上挣扎:我不能写“\”,因为这是错误的,但如果我使用“\\"应用无法呈现公式。 url += "This is a
当我只有一项时,我在使用 ng-repeat 时遇到了一些问题。 这是我的 Controller 中的部分代码: Data.get('company').then(function(data){
我是一名优秀的程序员,十分优秀!