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

jsp sql 网站开发最新国际要闻

jsp sql 网站开发,最新国际要闻,网站建设seo规范,全国大学生平面设计大赛这道题可以看成一个24叉树。 因为基因序列长度固定为8,且每个位置的字母固定是AGCT,可以选择改变的只有3个字母,所以一次最多24种情况。 然后检查变化后的结果是否存在bank中(使用hashSet来存储),同时设置…

这道题可以看成一个24叉树。

因为基因序列长度固定为8,且每个位置的字母固定是AGCT,可以选择改变的只有3个字母,所以一次最多24种情况。

然后检查变化后的结果是否存在bank中(使用hashSet来存储),同时设置一个visited集合来检查是否访问过。

class Solution {public int minMutation(String startGene, String endGene, String[] bank) {if (startGene.equals(endGene))return 0;char[] keys = { 'A', 'G', 'C', 'T' };Set<String> cnt = new HashSet<>();Set<String> visited = new HashSet<>();for (String str : bank) {cnt.add(str);}if (!cnt.contains(endGene))return -1;Queue<String> q = new ArrayDeque<>();q.offer(startGene);visited.add(startGene);int step = 1;while (!q.isEmpty()) {int size = q.size();for (int i = 0; i < size; ++i) {String curr = q.poll();for (int u = 0; u < 8; ++u) {for (int v = 0; v < 4; ++v) {if (keys[v] != curr.charAt(u)) {StringBuffer sb = new StringBuffer(curr);sb.setCharAt(u, keys[v]);String next = sb.toString();if (!visited.contains(next) && cnt.contains(next)) {if (next.equals(endGene))return step;visited.add(next);q.offer(next);}}}}}++step;}return -1;}
}

拓展:Queue使用ArrayList和LinkedList进行声明的区别
在Java中,Queue可以使用ArrayList和LinkedList进行声明。这两种数据结构在实现Queue时有一些区别。

使用ArrayList声明Queue的区别:

  1. 底层数据结构

    • ArrayList基于动态数组实现,它可以动态增长和缩小。
    • 插入和删除元素可能涉及重新分配内存和数据复制。
  2. 适用场景

    • 当需要随机访问队列中的元素时,ArrayList是更好的选择,因为它支持通过索引直接访问元素。
    • 如果需要频繁对队列进行随机访问、而且对队列的修改操作相对较少时,可以考虑使用ArrayList实现Queue。

使用LinkedList声明Queue的区别:

  1. 底层数据结构

    • LinkedList基于双向链表实现,每个元素都指向前一个和后一个元素。
    • 插入和删除元素的时间复杂度为O(1),因为只需要调整指针而不需要大量数据的搬移。
  2. 适用场景

    • 当需要频繁对队列进行插入、删除操作时,LinkedList是更好的选择,因为它的插入和删除操作效率更高。
    • 如果队列的操作主要是在两端进行(即头部和尾部),比如经常需要在队列头部和尾部进行插入、删除操作,可以考虑使用LinkedList实现Queue。

综合考虑:

  • 如果对队列中的元素进行频繁的随机访问,可以选择ArrayList实现Queue。
  • 如果对队列中的元素进行频繁的插入、删除操作,可以选择LinkedList实现Queue。

在实际应用中,需要根据具体的场景和需求来选择合适的数据结构来实现Queue。

http://www.15wanjia.com/news/19200.html

相关文章:

  • 做电影网站怎么赚钱长沙网站排名推广
  • 建立百度网站推广公司属于什么公司
  • 网站设计的目的和意义中关村在线app
  • 网站 关于我们 模板小红书推广策略
  • 乐趣做网站信息流广告有哪些投放平台
  • 一个网站做数据分析要多少钱轻松seo优化排名
  • b2b网站建设规则百度收录提交申请网站
  • 某班级网站建设方案100大看免费行情的软件
  • fireworks做网站seo工作内容
  • 微博网站可以做兼职吗网站关键词排名优化
  • 如何申请企业邮箱流程seo优化总结
  • 东营市两学一做考试网站南京seo外包平台
  • 买做指甲的材料在哪个网站西地那非片能延时多久有副作用吗
  • 大型网站建设开发设计公司推广软件赚钱
  • 哪家网站开发好chrome官网
  • 专业网站制作公司案例广告推广平台代理
  • 机器封所有端口 不支持做网站免费推广平台哪些比较好
  • 什么是网站推广免费网站推广网站破解版
  • 表格网站滚动字体怎么做的如何做网站优化seo
  • 个人建站做淘客网站备案win7优化大师
  • 做网站北京公司软文营销方案
  • 北京设计机构福州专业的seo软件
  • 织梦cms 做视频网站金花关键词工具
  • 东莞建站模板搭建做app的网站
  • 帮客户做违法网站违法么网络seo哈尔滨
  • 陕西网站建设公司网站没有友情链接
  • 做网站需要什么花费最受欢迎的十大培训课程
  • 石家庄网站关键词网站排名推广软件
  • 个人做网站能备案吗电商网站策划
  • 教育类网站开发模板地方网站建设