当前位置: 首页 > news >正文

wordpress 文章模版seo教程seo教程

wordpress 文章模版,seo教程seo教程,广州天河区房价2021最新价格,菠菜网站开发一条龙题目: 图的深度优先搜索 描述: 图的深度优先搜索类似于树的先根遍历,是树的先根遍历的推广。即从某个结点开始,先访问该结点,然后深度访问该结点的第一棵子树,依次为第二顶子树。如此进行下去,直…

题目:

图的深度优先搜索
描述:
图的深度优先搜索类似于树的先根遍历,是树的先根遍历的推广。即从某个结点开始,先访问该结点,然后深度访问该结点的第一棵子树,依次为第二顶子树。如此进行下去,直到所有的结点都访问为止。在该题中,假定所有的结点以“A”至“Z”中的若干字符表示,且要求结点的访问顺序根据“A”至“Z”的字典顺序进行访问。例如有如下图:

如果要求从H开始进行深度优先搜索,则搜索结果为:H->A->K->U->E.
输入:
输入只包含一个测试用例,第一行为一个自然数n,表示顶点的个数,第二行为n个大写字母构成的字符串,表示顶点,接下来是为一个n*n大小的矩阵,表示图的邻接关系。数字为0表示不邻接,否则为相应的边的长度。
最后一行为一个字符,表示要求进行深度优先搜索的起始顶点。
输出:
用一行输出深度优先搜索结果,起始点为给定的顶点,各顶点之间用一个空格隔开(注意后面的提示)。

样例输入:
5
HUEAK
0 0 2 3 0
0 0 0 7 4
2 0 0 0 0
3 7 0 0 1
0 4 0 1 0
H

样例输出:
H A K U E

代码:

代码与图的广度搜索差不多,不同的就是将队列变为栈

以下两个代码都差不多,都是利用对应的ascll码转换成0~25相应的数字,理论上来说是一样的

权值在本题没有使用

需注意如图:

输入:

5
HUEAG
0 0 2 3 0
0 0 0 7 4
2 0 0 0 0
3 7 0 0 1
0 4 0 1 0
U

输出:

U A G H E 

第一个栈直接储存字符,使用时换成数字

import java.util.Scanner;
import java.util.Stack;public class Xingyuxingxi {public static void main(String[] args){Scanner sc=new Scanner(System.in);int a=sc.nextInt();String b=sc.next();int [][]g=new int[26][26];boolean []pd=new boolean[26];//记录结点是否遍历过for (int i = 0; i < a; i++) {for (int j = 0; j < a; j++) {g[b.charAt(i)-'A'][b.charAt(j)-'A'] = sc.nextInt();//把字符转换成1~25的相应下标,当假设b.charAt(i)='A',b.charAt(j)='B',则相当于用0与1有个边,表示'A'与'B'有个边}}Stack<Character>zhan=new Stack<Character>();char d=sc.next().charAt(0);zhan.push(d);while(!zhan.isEmpty()){d=zhan.pop();int y=d-'A';if(!pd[y])System.out.print(d+" ");pd[y]=true;for (int i = 25; i >=0 ; i--) {//从最后一个字母开始入栈,保证了小的字母先出栈,栈先进后出if(g[y][i]!=0&&!pd[i])//非0表示有连接,false表示没被标记,权值在这里没有用{char zm=(char)(i+'A');zhan.push(zm);}}}}
}

第二个先全部换成数字,栈储存数字,最后输出转换成字符

import java.util.Scanner;
import java.util.Stack;public class Xingyuxingxi {public static void main(String[] args){Scanner sc=new Scanner(System.in);int a=sc.nextInt();String b=sc.next();int [][]g=new int[26][26];boolean []pd=new boolean[26];//记录结点是否遍历过for (int i = 0; i < a; i++) {for (int j = 0; j < a; j++) {g[b.charAt(i)-'A'][b.charAt(j)-'A'] = sc.nextInt();//把字符转换成1~25的相应下标,当假设b.charAt(i)='A',b.charAt(j)='B',则相当于用0与1有个边,表示'A'与'B'有个边}}Stack<Integer>zhan=new Stack<Integer>();char d=sc.next().charAt(0);zhan.push(d-'A');while(!zhan.isEmpty()){int y=zhan.pop();if(!pd[y])System.out.print((char)(y+'A')+" ");pd[y]=true;for (int i = 25; i >=0 ; i--) {//从最后一个字母开始入栈,保证了小的字母先出栈,栈先进后出if(g[y][i]!=0&&!pd[i])//非0表示有连接,false表示没被标记,权值在这里没有用{zhan.push(i);}}}}
}

http://www.yidumall.com/news/27436.html

相关文章:

  • 惠州市网站建设中关村在线app
  • 做网站用什么虚拟主机免费发广告的平台有哪些
  • 江苏网站建设系统服务信息流优化师培训机构
  • 大连九死一疯事件seo零基础培训
  • 网站降权查下今日刚刚发生新闻事件
  • 先做网站主页还是先上架宝贝网店seo排名优化
  • 本网站正在建设中磁力吧ciliba
  • 学会网站建设目的网站托管维护
  • 做网站的开发软件是什么天津seo排名收费
  • 杭州网站建设哪家公司好搜索软件排行榜前十名
  • 如何上传安装网站模板电商网络营销
  • 视频播放网站开发北京百度推广代理
  • 深圳电子商务网站制作google关键词分析工具
  • 优推宝可以做自己网站吗汕头seo全网营销
  • 最好的营销网站网站关键词在哪里看
  • 网站建设需要的硬件网站宣传费用
  • 购物网站的后台做哪些东西艾瑞指数
  • 设计师个人网站主页浏览器下载
  • 学做效果图网站知乎推广公司
  • php网站制作软件西藏自治区seo 标题 关键词优化
  • 网上怎么做网站赚钱网站制作软件
  • 免费微网站系统源码高级seo招聘
  • 连城县住房和城乡建设局 网站网络推广推广
  • 淘客网站添加到桌面全球搜
  • 使用vue做简单网站教程seo实战论坛
  • 搭建一个商城类网站南宁百度推广seo
  • 做一网站要什么2020新闻大事件摘抄
  • 贵阳网站建设方案杭州排名优化软件
  • 网页制作导航栏沈阳专业网站seo推广
  • 龙港哪里有做阿里巴巴网站美业推广平台