图的深度优先遍历

利用栈实现。

从源点开始按照深度把节点放入栈中,然后再弹出。

每弹出一个节点,把该节点一个没有进入栈中的节点放入栈中,并把该节点也放入栈中,方便回溯。

直到栈变空。

public static void dfs(Node node) {
		if(node == null) {
			return;
		}
		Stack<Node> stack =  new Stack<Node>();
		HashSet<Node> set = new HashSet<Node>();
		
		stack.push(node);
		set.add(node);
		System.out.println(node.value);
		while(!stack.isEmpty()) {
			Node cur = stack.pop();
			for(Node next:cur.nexts) {
				if(!set.contains(next)) {
					stack.push(cur);//把当前元素也压入栈中是为了可以回溯。
					//如果不压入栈中,等一条路走不通的时候,无法往后回溯去其他路。
					stack.push(next);
					set.add(next);
					System.out.println(next.value);
					break;
				}
				
				
			}
			
			
			
			
		}
		
		
	}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: HBase伪分布式环境搭建步骤如下: 1. 安装Java环境 HBase是运行在Java环境下的,所以需要先安装Java环境。可以从官网下载Java安装包,或者使用Linux自带的OpenJDK。 2. 下载HBase 从官网下载HBase安装包,或者使用以下命令下载: ``` wget http://mirror.bit.edu.cn/apache/hbase/hbase-2.4.6/hbase-2.4.6-bin.tar.gz ``` 3. 解压HBase 使用以下命令解压HBase: ``` tar -zxvf hbase-2.4.6-bin.tar.gz ``` 4. 配置HBase 进入HBase目录,编辑conf/hbase-site.xml文件,添加以下内容: ``` <configuration> <property> <name>hbase.rootdir</name> <value>file:///home/hbase/hbase-data</value> </property> <property> <name>hbase.zookeeper.property.dataDir</name> <value>/home/hbase/zookeeper-data</value> </property> </configuration> ``` 其中,hbase.rootdir指定HBase数据存储目录,hbase.zookeeper.property.dataDir指定Zookeeper数据存储目录。 5. 启动HBase 进入HBase目录,使用以下命令启动HBase: ``` ./bin/start-hbase.sh ``` 启动后,可以使用以下命令查看HBase状态: ``` ./bin/hbase shell status ``` 6. 停止HBase 使用以下命令停止HBase: ``` ./bin/stop-hbase.sh ``` 注意:以上步骤是在伪分布式环境下搭建HBase,如果要在分布式环境下搭建HBase,则需要在多台机器上安装HBase,并在配置文件中指定各自的角色和IP地址。 ### 回答2: HBase是一个分布式的、面向列的NoSQL数据库,搭建HBase的伪分布式环境可以在单个节点上模拟出分布式集群的效果,方便进行开发和测试。 首先,我们需要确保安装好了Hadoop集群,因为HBase是构建在Hadoop之上的。接下来,我们可以按照以下步骤搭建HBase的伪分布式环境: 1. 下载HBase:在官方网站上下载HBase的安装包,并解压到你希望的安装目录下。 2. 配置HBase:打开HBase的配置文件hbase-site.xml,修改以下几个参数: - hbase.rootdir:设置HDFS中存储HBase数据的根目录,例如:hdfs://localhost:9000/hbase - hbase.zookeeper.property.dataDir:设置ZooKeeper的本地目录,例如:/home/hadoop/hbase/zookeeper - hbase.cluster.distributed:设置为true,表示以分布式模式运行HBase 3. 配置Hadoop:打开Hadoop的配置文件core-site.xml,修改以下参数: - fs.defaultFS:设置为HDFS的地址,例如:hdfs://localhost:9000 4. 启动Hadoop集群:通过启动Hadoop的sbin目录下的start-all.sh脚本,启动Hadoop集群。 5. 启动HBase集群:在HBase的安装目录下,执行bin/start-hbase.sh脚本,启动HBase集群。 6. 验证:可以通过访问HBase自带的Web界面,在浏览器中输入http://localhost:16010,查看HBase的状态和管理界面。如果能正常访问,说明HBase的伪分布式环境搭建成功。 在这个伪分布式环境中,HBase会在本地运行一个ZooKeeper实例,用于管理HBase的协调和管理器。同时,HBase会将数据存储在HDFS上,实现数据的分布式存储和处理。 总之,利用上述步骤,我们可以在单个节点上搭建HBase的伪分布式环境,方便进行开发、测试和学习。 ### 回答3: 为了在educoder上搭建HBase伪分布式环境,我们需要按照以下步骤进行操作。 步骤一:安装Hadoop 首先,我们需要在系统上安装Hadoop。可以从Apache官网下载Hadoop的压缩包,然后解压到指定的目录。在解压后的目录中,进行一些必要的配置,例如设置环境变量和修改配置文件等。然后,启动Hadoop集群。 步骤二:安装HBase 在安装HBase之前,我们还需要确保系统上已经安装了Java和Hadoop。同样地,我们可以从Apache官网下载HBase的压缩包,并解压到指定的目录。然后,进行一些必要的配置,例如设置环境变量和修改配置文件等。接下来,启动HBase服务。 步骤三:创建HBase表 在HBase中创建表之前,我们需要先使用HBase命令行工具进行连接。然后,使用HBase的API或命令行工具创建表,指定表的名称和列簇等。可以通过shell命令或编程方式添加和查询数据。 步骤四:验证功能 在搭建完HBase伪分布式环境并创建表后,我们可以通过HBase命令行工具或编程方式验证其功能。例如,可以使用HBase shell命令进行数据的添加、查询、更新和删除等操作,也可以使用HBase的API进行编程实现。 通过以上步骤,我们就可以在educoder上搭建起HBase伪分布式环境,并且能够进行一些基本的操作和验证功能。当然,在实际应用中,我们还可以进一步配置和优化HBase,以提高系统的性能和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值