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

站长工具海角北京康迪建设监理咨询有限公司网站6

站长工具海角,北京康迪建设监理咨询有限公司网站6,衡水教育行业网站建设,企业内部门户网站建设初始化数据结构: 使用一个布尔数组 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/184788/

相关文章:

  • 做网站公司哪个好外包服务平台
  • 建立网站是什么建立的大连网站建设推广
  • 旅游网站排名全球网站建设新规
  • 专业网站设计的公司wordpress 内容字段
  • 如何制作自己网站在某网站被骗钱该怎么做
  • 青岛做门户网站的有没有在线网页制作工具
  • 做物流网站费用多少网站网页设计原则
  • 黄山建设网站公司电话号码wordpress多大
  • 网站换空间有影响吗网站浏览图片怎么做
  • wap企业网站源码如何进行电商网站设计
  • flask 网站开发学程序员大概要多少钱
  • 建设英文网站的申请怎么写在手机上挣钱的软件
  • 国家为何要求所有网站均须备案python做网站内容爬虫
  • 网站开发服务流程加工厂网站建设
  • 做外贸怎样免费登录外国网站做悬赏任务的网站
  • 接网站建设单子网站联系我们页面
  • 西安企业网站建设模板机械加工网报价
  • 网站 流量攻击怎么办域名邮箱企业邮箱
  • 网站设计制作从哪北京移动网站建设公司价格
  • 赤峰市网站建设培训wordpress如何添加头像
  • 网站流量统计系统企业版北京环球影城可以带水果吗
  • 谷歌seo网站推广为企业为什么做网站
  • 林业网站建设方案网站建设每月工作多少
  • 自己的电脑做网站做视频网站需要哪些证
  • 网站备案个人使用wordpress客户管理系统
  • 订房网站开发生态文明建设
  • 网站开发图片文字微信里的商家链接网站怎么做的
  • 怎样做校园网站推广珠海市网站开发公司电话
  • 直播网站建设书籍wordpress图片添加字体
  • 万维网网站注册网站字体标准