希望有人能帮我解决一下这个bug

weixin_37844902 2017-12-12 10:17:42
我在写一个并查集类,用的是Visual C++6.0。一运行到cout那里就报错,可是把这些代码搬到CodeBlocks就能正常运行。
代码和错误见下:


#include "stdafx.h"
#include "DisjointSet.h"
#include <iostream>
using namespace std;

void test(){
DisjointSet set(10);
cout << "5所在树的根为" << set.Find(5) << endl;
//printf("5所在树的根为%d\n",set.Find(5));
}

int main(int argc, char* argv[])
{
test();
return 0;
}


//DisjointSet.h

#ifndef _DISJOINTSET
#define _DISJOINTSET

class DisjointSet{
private:
int size;
int* parent;

public:
DisjointSet(int s);
void Union(int root1,int root2);
int Find(int x);
};

#endif


//DisjointSet.cpp

#include "DisjointSet.h"
DisjointSet::DisjointSet(int s){
size = s;
parent = new int(size);
for(int i=0;i<size;++i) parent[i] = -1;
}

void DisjointSet::Union(int root1,int root2){
if(root1 == root2) return;
if(parent[root1] < parent[root2]){
parent[root2] = root1;
}else if(parent[root1] > parent[root2]){
parent[root1] = root2;
}else{
parent[root1]--;
parent[root2] = root1;
}
}

int DisjointSet::Find(int x){
if(parent[x] < 0) return x;
return parent[x] = Find(parent[x]);
}




我把cout改成c语言的printf,也能正常运行。请问这到底是怎么回事?希望有人能帮忙解惑。
...全文
118 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
幻夢之葉 2017-12-13
  • 打赏
  • 举报
回复
//parent = new int[size];,使用括号是申请一个空间并初始化为size,申请分配数组用中括号才对。否则后续操作将会导致越界读写,之后崩溃 //CodeBlocks不崩溃只是Debug下并且是巧合 parent = new int(size); for(int i=0;i<size;++i) parent[i] = -1;

64,642

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧