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

如何选择网站制作公司推动

如何选择网站制作公司,推动,大丰网店制作,邢台网站建设03191688初始化数据结构: 使用一个布尔数组 arr 来表示每个位置是否被占用。初始时所有位置均为 false(未占用)。使用一个 LinkedHashMap(命名为 queue)来记录最近的 R 操作的位置。这个结构可以保持插入顺序,方便后…
  • 初始化数据结构

    • 使用一个布尔数组 arr 来表示每个位置是否被占用。初始时所有位置均为 false(未占用)。
    • 使用一个 LinkedHashMap(命名为 queue)来记录最近的 R 操作的位置。这个结构可以保持插入顺序,方便后续处理。
  • 遍历输入字符串

    • 遍历每个字符,根据字符的类型(.LR)进行不同的处理:
      • .:表示空位,跳过。
      • L
        • 如果 queue 为空(没有 R),将当前位置之前的所有位置标记为占用(true)。
        • 如果 queue 不为空,处理最近的 R
          • queue 中获取并移除最近的 R 的位置。
          • 计算从这个 R 到当前 L 之间的影响区域,并根据位置关系决定标记的方式。具体来说,如果 LR 之间的距离是偶数,则需要跳过中间位置;如果是奇数,则可以直接标记所有位置为占用。
      • R:将当前索引加入 queue,以备后续处理。
  • 处理剩余的 R

    • 遍历完字符串后,如果 queue 中还有 R,取出第一个 R 的位置,将这个位置及其后所有位置标记为占用。
  • 计算未占用的位置

    • 遍历 arr 数组,统计未被占用的位置,并将它们的索引(1-based)加入结果队列。
  • 构造结果字符串

    • 如果没有未占用的位置,返回 "0"
    • 否则,构造结果字符串,格式为 "count:pos1,pos2,...",并返回。
import java.util.ArrayDeque;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Iterator;public class Main {public static String solution(int num, String data) {boolean[] arr = new boolean[data.length()];LinkedHashMap<Character, Integer> queue = new LinkedHashMap<>();for (int i = 0; i < data.length(); i++) {switch (data.charAt(i)) {case '.':break;case 'L':if (queue.isEmpty()) {for (int j = 0; j <= i; j++) {arr[j] = true;}} else {Iterator<Map.Entry<Character, Integer>> iterator = queue.entrySet().iterator();Map.Entry<Character, Integer> firstEntry = iterator.next(); // 获取第一个条目iterator.remove();boolean skipTwo = false;int top = firstEntry.getValue();int extra = (i + top) / 2;if ((i - top) % 2 != 0) {skipTwo = true;}for (int j = top; j <= i; j++) {if (skipTwo) {arr[j] = true;} else {if (j != extra) {arr[j] = true;}}}}break;case 'R':queue.put('R', i);break;}}// Check if the queue is not emptyif (!queue.isEmpty()) {// Retrieve and remove the first entryIterator<Map.Entry<Character, Integer>> iterator = queue.entrySet().iterator();Map.Entry<Character, Integer> firstEntry = iterator.next();iterator.remove(); // Pop the first entryif (firstEntry.getKey() == 'R') {int topValue = firstEntry.getValue();for (int j = topValue; j < arr.length; j++) {arr[j] = true; // Set all subsequent elements to true}}}int count = 0;ArrayDeque<Integer> result = new ArrayDeque<>();for (int i = 0; i < data.length(); i++) {if (!arr[i]) {count++;result.add(i + 1); // 1-based index}}if (count == 0) {return "0"; // All positions are filled}StringBuilder resultString = new StringBuilder(count + ":");for (int pos : result) {resultString.append(pos).append(",");}resultString.setLength(resultString.length() - 1); // Remove the last commareturn resultString.toString();}public static void main(String[] args) {// // You can add more test cases hereSystem.out.println(solution(14, ".L.R...LR..L..").equals("4:3,6,13,14"));System.out.println(solution(5, "R....").equals("0"));System.out.println(solution(1, ".").equals("1:1"));}
}

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

相关文章:

  • 郑州网站制作怎么样濮阳网络科技有限公司
  • 一个网站开发背景是什么wordpress群发留言
  • 广州网站建设工作室管理网站用什么系统好
  • 外贸网站优化排名电商平台如何宣传
  • 文山网站建设代理百度游戏排行榜风云榜
  • 重庆企业网站营销设计建设视频网站费用
  • 南通企业网站制作用wordpress做直播平台
  • 做装潢网站WordPress的站内地图
  • 网络营销 网站上海网站开发前十名
  • 做网站商城如何优化高水平的徐州网站建设
  • 企业网站可以免费做吗承德网站制作
  • 杭州网络公司网站html5移动网站模板
  • 企业宣传网站建设网页设计版权怎么写
  • 网站飘窗 两学一做WordPress评级主题
  • 海创网站建设软件系统开发公司
  • 在那里建立公司网站医药网站开发
  • 网站做单链 好不好做网站一次付费
  • 可视化建站源码个人网站用什么服务器
  • 网站公司用什么软件做网站title 网站建设公司实力
  • 如何做搜索网站网站做游戏吗
  • 电子商务网站建设规划说明书浦江县城乡建设局网站
  • 站长网网站模板某旅行社网站建设规划书
  • 龙岗做网站建设购物网址大全
  • 建筑人才网官方网站评职称电商erp软件排名
  • iis添加网站访问权限淄博网站建设团队
  • 网站底部友情链接怎么做的招投标网站建设
  • 运城网站建设公司有多少钱tp框架做商城网站怎么用缓存
  • 建一个在线商城网站百度网站地图在线生成
  • 网站策划的前景网站网页压缩
  • 商业网站建设费用建站用什么搭建比较好