#include<iostream> using namespace std; class abc { public: int i; abc(int i){ i = i; } }; main(){ abc m(5); cout<<m.i; }的输出结果

时间: 2023-07-14 13:09:04 浏览: 44
该代码的输出结果将是一个不确定的值,而不是期望的5。这是因为在构造函数中,你试图将参数i赋值给类的成员变量i,但是由于参数名和成员变量名相同,所以赋值操作实际上是将参数i赋值给自身,而不是类的成员变量。因此,类的成员变量i保持不变,仍然是一个未初始化的值。因此,输出结果将是一个未定义的值。为了解决这个问题,你可以使用初始化列表来正确地初始化成员变量。修改构造函数如下: ```cpp abc(int val) : i(val) { } ``` 这样,参数val会被正确地赋值给类的成员变量i,输出结果将会是期望的5。
相关问题

#include<iostream> using namespace std; class abc { public: int i; abc(int i) { i =i; } }; main() { abc m(5); cout<<m.i;}

你的代码有一个小错误。在构造函数中,你应该使用成员初始化列表来初始化类成员变量,而不是在构造函数体内进行赋值。修正后的代码如下: ```cpp #include<iostream> using namespace std; class abc { public: int i; abc(int i) : i(i) { } }; int main() { abc m(5); cout << m.i; return 0; } ``` 这样修改后,输出结果将为 `5`。

#include<iostream> using namespace std; class abc { public: int i; abc(int i){ i = i; } }; main(){ abc m(5); cout<<m.i; }

你的代码中有一个类叫做abc,它有一个公共变量i。类abc有一个构造函数,参数为int型的i。在构造函数中,你试图将参数i赋值给类的成员变量i,但是由于参数名和成员变量名相同,所以会导致赋值不成功。在主函数中,你创建了一个abc类的对象m,并将参数值设为5。最后,输出m对象的成员变量i。根据你的代码逻辑,期望输出结果应该是5。

相关推荐

帮我修改下面这个代码:#include <iostream> #include <queue> using namespace std; struct Node { int number; int father; int floor; bool bl = false; }; class dls { private: int n; Node* node; int** map; public: dls(int n) :n(n) { node = new Node[n]; } void Map() // 建立邻接矩阵的下三角并初始化 { map = new int* [n]; for (int i = 0; i < n; i++) { map[i] = new int[i + 1]; for (int j = 0; j <= i; j++) map[i][j] = 0; } } void createGraph() // 对邻接矩阵进行赋值 { cout << "请输入村庄的" << n - 1 << "条道路:" << endl; for (int i = 0; i < n - 1; i++) { int x, y; cin >> x >> y; if (x >= y) map[x][y] = 1; else map[y][x] = 1; } } void BFSTree()// 利用 BFS 建立树 { queue<int>qu; qu.push(0); node[0].father = 0; node[0].floor = 0; node[0].bl = true; while (!qu.empty()) { int x = qu.front(); qu.pop(); for (int i = 0; i < n; i++) { if ((map[x][i] == 1 || map[i][x] == 1) && node[i].bl == false) { node[i].bl = true; node[i].father = x; node[i].floor = node[x].floor + 1; qu.push(i); } } } } int findFather(int m, int n) // 寻找父亲结点 { int my_m = m; int my_n = n; int gap; if (node[m].floor > node[n].floor) { gap = node[m].floor - node[n].floor; for (int i = 0; i < gap; i++) my_m = node[my_m].father; } else { gap = node[n].floor - node[m].floor; for (int i = 0; i < gap; i++) my_n = node[my_n].father; } while (my_m != my_n) { my_m = node[my_m].father; my_n = node[my_n].father; } return my_m; } }; int main() { int T; int N; int M; cout << "请输入需要测试的组数:"; cin >> T; while (T--) { cout << "请输入村庄个数:"; cin >> N; dls ddd(N); ddd.Map(); ddd.createGraph(); ddd.BFSTree(); cout << "请输入需要测试的问题数:"; cin >> M; for (int i = 1; i <= M; i++) { int a, b, c; cout << "请依次输入abc的编号: "; cin >> a >> b >> c; int ab = ddd.findFather(a, b); int ac = ddd.findFather(a, c); int bc = ddd.findFather(b, c); if (ac == c && bc == c && ab == c) cout << "Yes" << endl; else if (ac == c && bc != c) cout << "Yes" << endl; else if (bc == c && ac != c) cout << "Yes" << endl; else cout << "No" << endl; } } return 0; }

帮我计算下面这段代码的时间复杂度和空间复杂度:#include <iostream> #include <queue> using namespace std; struct Node { int number;//结点编号 int father;//父结点 int floor;//记录层数 bool bl = false;//记录是否被访问 }; class dls { private: int n;//村庄个数 Node* node;//结点数组 int** map; public: dls(int n) :n(n) { node = new Node[n];} void Map() // 建立邻接矩阵的下三角并初始化 { map = new int* [n]; for (int i = 0; i < n; i++) { map[i] = new int[i + 1]; for (int j = 0; j <= i; j++) map[i][j] = 0; } } void createGraph() // 对邻接矩阵进行赋值 { cout << "请输入村庄的" << n - 1 << "条道路:" << endl; for (int i = 0; i < n - 1; i++) { int x, y; cin >> x >> y; if (x >= y) map[x][y] = 1; else map[y][x] = 1; } } void BFSTree()// 利用 BFS 建立树 { queue<int> qu; qu.push(0); node[0].father = 0; node[0].floor = 0; node[0].bl = true; while (!qu.empty()) { int x = qu.front(); qu.pop(); for (int i = 0; i < n; i++) { if ((map[x][i] == 1 || map[i][x] == 1) && node[i].bl == false) { node[i].bl = true; node[i].father = x; node[i].floor = node[x].floor + 1; qu.push(i); } } } } int findFather(int m, int n) // 寻找父亲结点 { int my_m = m; int my_n = n; int gap; if (node[m].floor > node[n].floor) { gap = node[m].floor - node[n].floor; for (int i = 0; i < gap; i++) my_m = node[my_m].father; } else { gap = node[n].floor - node[m].floor; for (int i = 0; i < gap; i++) my_n = node[my_n].father; } while (my_m != my_n) { my_m = node[my_m].father; my_n = node[my_n].father; } return my_m; } }; int main() { int T;//测试组数 int N;//村庄个数 int M;//问题个数 cout << "请输入需要测试的组数:"; cin >> T; while (T--) { cout << "请输入村庄个数:"; cin >> N; dls ddd(N); ddd.Map(); ddd.createGraph(); ddd.BFSTree(); cout << "请输入需要测试的问题数:"; cin >> M; for (int i = 1; i <= M; i++) { int a, b, c; cout << "请依次输入abc的编号(编号需小于村庄数): "; cin >> a >> b >> c; int ab = ddd.findFather(a, b); int ac = ddd.findFather(a, c); int bc = ddd.findFather(b, c); if (ac == c && bc == c && ab == c) cout << "Yes" << endl; else if (ac == c && bc != c) cout << "Yes" << endl; else if (bc == c && ac != c) cout << "Yes" << endl; else cout << "No" << endl; } } return 0; }

最新推荐

recommend-type

静态数据链接库 教你制作数据动态链接库

#include&lt;iostream&gt; using namespace std; #include&lt;string&gt; class student { private: int id; string name; int score; public: student(int idd,string nam,int scor); void display(); }; stuapp.cpp...
recommend-type

####这是一篇对python的详细解析

python
recommend-type

菜日常菜日常菜日常菜日常

菜日常菜日常菜日常菜日常
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

MATLAB柱状图在数据分析中的作用:从可视化到洞察

![MATLAB柱状图在数据分析中的作用:从可视化到洞察](https://img-blog.csdnimg.cn/img_convert/1a36558cefc0339f7836cca7680c0aef.png) # 1. MATLAB柱状图概述** 柱状图是一种广泛用于数据可视化的图表类型,它使用垂直条形来表示数据中不同类别或组别的值。在MATLAB中,柱状图通过`bar`函数创建,该函数接受数据向量或矩阵作为输入,并生成相应的高度条形。 柱状图的优点在于其简单性和易于理解性。它们可以快速有效地传达数据分布和组别之间的比较。此外,MATLAB提供了广泛的定制选项,允许用户调整条形颜色、