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

做dhl底单的网站是 什么衡水seo外包

做dhl底单的网站是 什么,衡水seo外包,做付费下载的网站,牡丹江百姓网免费发布信息按字典 wordList 完成从单词 beginWord 到单词 endWord 转化,一个表示此过程的 转换序列 是形式上像 beginWord -> s1 -> s2 -> ... -> sk 这样的单词序列,并满足: 每对相邻的单词之间仅有单个字母不同。转换过程中的每个单词 s…

按字典 wordList 完成从单词 beginWord 到单词 endWord 转化,一个表示此过程的 转换序列 是形式上像 beginWord -> s1 -> s2 -> ... -> sk 这样的单词序列,并满足:

  • 每对相邻的单词之间仅有单个字母不同。
  • 转换过程中的每个单词 si1 <= i <= k)必须是字典 wordList 中的单词。注意,beginWord 不必是字典 wordList 中的单词。
  • sk == endWord

给你两个单词 beginWord 和 endWord ,以及一个字典 wordList 。请你找出并返回所有从 beginWord 到 endWord 的 最短转换序列 ,如果不存在这样的转换序列,返回一个空列表。每个序列都应该以单词列表 [beginWord, s1, s2, ..., sk] 的形式返回。

思路一:BFS

char** list;
int** back;
int* backSize;void dfs(char*** res, int* rSize, int** rCsize, int* ans, int last, int retLevel){int i = ans[last];if(i == 0){res[*rSize] = (char**)malloc(sizeof(char*) * retLevel);(*rCsize)[*rSize] = retLevel;for(int j = 0; j < retLevel; j++){res[*rSize][j] = list[ans[j]];}(*rSize)++;}if(last == 0){return;}for(int j = 0; j < backSize[i]; j++){int k = back[i][j];ans[last-1] = k;dfs(res,rSize,rCsize,ans,last-1,retLevel);}
}char *** findLadders(char * beginWord, char * endWord, char ** wordList, int wordListSize, int* returnSize, int** returnColumnSizes){*returnSize = 0;int size = wordListSize+1;int wlen = strlen(beginWord);list = (char**)malloc(sizeof(char*)*size); back = (int**)malloc(sizeof(int*) * size);  backSize = (int*)malloc(sizeof(int) * size);int* visited = (int*)malloc(sizeof(int) * size); int** diff = (int**)malloc(sizeof(int*) * size);  int* diffSize = (int*)malloc(sizeof(int) * size);int endidx = 0;for (int i = 0; i < size; ++i) {list[i] = i == 0 ? beginWord : wordList[i - 1];visited[i] = 0;diff[i] = (int*)malloc(sizeof(int) * size);diffSize[i] = 0;back[i] = (int*)malloc(sizeof(int) * size);backSize[i] = 0;if (strcmp(endWord, list[i]) == 0) {endidx = i;}}if (endidx == 0) return 0;  // endword is not in the list// collect diff datafor (int i = 0; i < size; ++i) {for (int j = i; j < size; ++j) {int tmp = 0;  // tmp is the difference between word[i] & word[j]for (int k = 0; k < wlen; ++k) {tmp += list[i][k] != list[j][k];if (tmp > 1) break;}if (tmp == 1) {diff[i][diffSize[i]++] = j;diff[j][diffSize[j]++] = i;}}}// BFSint* curr = (int*)malloc(sizeof(int) * size); int* prev = (int*)malloc(sizeof(int) * size);  int prevSize, currSize = 1;int* currvisited = (int*)malloc(sizeof(int) * size);int level = 1;                                     curr[0] = 0;visited[0] = 1;int retlevel = 0;  while (retlevel == 0 && currSize > 0) {++level;int* tmp = prev;prev = curr;curr = tmp;prevSize = currSize;currSize = 0;for (int i = 0; i < size; ++i) {currvisited[i] = 0;}for (int i = 0; i < prevSize; ++i) {for (int j = 0; j < diffSize[prev[i]]; ++j) {int k = diff[prev[i]][j];  if (visited[k]) continue;back[k][backSize[k]++] = prev[i];   if (k == endidx) retlevel = level;  if (currvisited[k]) continue;       curr[currSize++] = k;currvisited[k] = 1;}}for (int i = 0; i < currSize; ++i) {visited[curr[i]] = 1;}}if (retlevel == 0) return 0;  char*** res = (char***)malloc(sizeof(char**) * size);int* ans = (int*)malloc(sizeof(int) * retlevel);*returnColumnSizes = (int*)malloc(sizeof(int) * size);ans[retlevel - 1] = endidx;dfs(res, returnSize, returnColumnSizes, ans, retlevel - 1, retlevel);return res;
}

分析:

本题采用广度优先搜索将每个字符串能转换的所有序列找出,再判断是否存在最短转换序列,最后输出答案

总结:

本题考察广度优先搜索的应用,判断当前字符是否匹配,得到转换序列即可做出

http://www.yayakq.cn/news/671747/

相关文章:

  • 云南专业建网站网站关键词优化怎么弄
  • 网站建设说全景效果图网站
  • 做网站编辑要会什么wordpress的发件邮箱是多少
  • 植物提取网站做的比较好的厂家微营销工具有哪些
  • 网站服务器时间在哪里查询论文收录网站有哪些
  • 易企秀网站开发凡客建站官网登录入口
  • 品牌查询网站 优帮云开发微信小程序多少钱
  • 打开网站提示建设中设计师常看的网站
  • 企业网站客户案例便宜虚拟主机做网站备份
  • 扬州市做网站企业网站改版
  • 网站备案转移网上商城网站建设解决方案
  • 榆林市网站seowordpress页面添加新闻
  • 做网站多少钱角西宁君博特惠企业网站建设对企业客户的意义
  • 滴滴出行的网站是哪家公司做的wordpress 修改 点击量
  • 创建网站服务器地址下载中心
  • 入侵网站做排名下载好了网站模板怎么开始做网站?
  • 编程猫官网seo包年优化费用
  • 物流网站建设平台分析邢台免费发布推广信息的平台
  • 实验室网站开发框架网站的建设思路
  • 产品少的电商网站怎么做个人房源网
  • 甘肃广川工程建设有限公司网站知网网站开发
  • 佛山招收网站设计石家庄网站搭建定制
  • 网站推广招商建筑工程网 装修
  • 网站做图标放在手机桌面广州网站建设哪个好
  • 中国美院网站建设公司增城建设局网站
  • wordpress推广网站插件广州做网站要多少钱
  • 图片生成器网站南昌定制网站开发
  • 百度秒收录的网站青海网络推广公司
  • 网站备案有期限吗注册了域名之后如何建立一个网站
  • 拼团做的比较好的网站无锡装修公司哪家口碑最好