中国大学MOOC-陈越、何钦铭-数据结构-2018秋——列出连通集

我的中国大学MOOC-陈越、何钦铭-数据结构-2018秋代码仓:https://github.com/617076674/MOOC-DataStructure-2018-Autumn

题目描述:

知识点:图的深度优先遍历、图的广度优先遍历

思路:图的深度优先遍历 + 图的广度优先遍历

由于题目假设我们从编号最小的顶点出发,按编号递增的顺序访问邻接点,因此我们需要对每个顶点的邻接点先进行从小到大排序。

时间复杂度和每个顶点的邻接点数量有关。空间复杂度是O(N + E)。

C++代码:

#include<iostream>
#include<vector>
#include<queue>
#include<algorithm>

using namespace std;

int N, E;
vector<int> graph[10], oneTimeTravel;
bool visited[10];

void dfs(int nowVisit);
void bfs(int nowVisit);

int main() {
	scanf("%d %d", &N, &E);
	int v1, v2;
	for(int i = 0; i < E; i++) {
		scanf("%d %d", &v1, &v2);
		graph[v1].push_back(v2);
		graph[v2].push_back(v1);
	}
	for(int i = 0; i < N; i++){
		sort(graph[i].begin(), graph[i].end());
	}
	fill(visited, visited + N, false);
	for(int i = 0; i < N; i++) {
		if(!visited[i]) {
			oneTimeTravel.clear();
			dfs(i);
			printf("{ ");
			for(int i = 0; i < oneTimeTravel.size(); i++) {
				printf("%d ", oneTimeTravel[i]);
			}
			printf("}\n");
		}
	}
	fill(visited, visited + N, false);
	for(int i = 0; i < N; i++) {
		if(!visited[i]) {
			oneTimeTravel.clear();
			bfs(i);
			printf("{ ");
			for(int i = 0; i < oneTimeTravel.size(); i++) {
				printf("%d ", oneTimeTravel[i]);
			}
			printf("}\n");
		}
	}
}

void dfs(int nowVisit){
	visited[nowVisit] = true;
	oneTimeTravel.push_back(nowVisit);
	for(int i = 0; i < graph[nowVisit].size(); i++){
		int v = graph[nowVisit][i];
		if(!visited[v]){
			dfs(v);
		}
	}
}

void bfs(int nowVisit){
	queue<int> q;
	q.push(nowVisit);
	visited[nowVisit] = true;
	while(!q.empty()){
		int u = q.front();
		oneTimeTravel.push_back(u);
		q.pop();
		for(int i = 0; i < graph[u].size(); i++){
			int v = graph[u][i];
			if(!visited[v]){
				q.push(v);
				visited[v] = true;
			}
		}
	}
}

C++解题报告:

 

### 关于中国大学MOOC翁恺C语言程序设计习题集的相关资源 在中国大学MOOC平台上,翁恺老师的《程序设计入门——C语言》课程因其高质量的教学内容而广受好评。该课程不仅提供了理论讲解,还通过丰富的练习帮助学习者巩固知识点[^1]。 对于希望获取更多习题及相关解答的学习者而言,可以参考以下几种方式: #### 1. **官方配套教材** 翁恺老师在其课程中推荐了一些经典的C语言书籍作为辅助材料。这些书通常会附带大量习题及其解析,能够有效补充线上课程的内容。例如,《C程序设计语言(第二版)》是一本经典教材,适合初学者深入理解C语言的核心概念[^4]。 #### 2. **社区讨论区** 每门MOOC课程都设有专门的论坛供学员交流心得与疑问。在“程序设计入门——C语言”的讨论区内,许多同学分享了自己的解题思路以及常见错误分析。积极参与此类互动不仅能解决具体问题,还能提升编程思维能力[^1]。 #### 3. **第三方网站上的整理资料** 网络上有不少热心网友基于个人学习经验总结出了完整的习题答案集合或者技巧指南。不过需要注意的是,在查阅他人成果时应注重理解和应用而非单纯抄袭;同时也要甄别信息来源的真实性以免受到误导。比如下面这个简单的位运算例子展示了如何正确打印十六进制数值并演示左移操作效果[^2]: ```c #include <stdio.h> int main() { unsigned char c = 0xA5; printf("c=%hhx\n", c); printf("c<<2=%hhx\n", c << 2); return 0; } ``` #### 4. **开发环境的选择建议** 为了更好地完成课后作业,选择合适的集成开发环境(IDE)至关重要。针对不同操作系统平台,可以选择如下工具之一来编写和调试代码:MS Visual Studio Express适用于Windows用户;MacOS X 用户则可选用Xcode;跨平台解决方案包括Eclipse-CDT、Geany搭配MinGW等轻量级选项也十分实用[^4]。 #### 5. **编译过程的理解有助于排查错误** 了解整个程序从源码到最终运行版本之间的转换流程可以帮助开发者快速定位潜在问题所在位置。一般情况下,这一链条涉及以下几个阶段:.c 文件经由预处理器生成.i文件,.i再交予编译器产出.s汇编代码,.s进一步转化为.o目标模块最后链接成.out可执行二进制文件[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值