• 前缀和
  • 二分查找
  • 打表枚举
  • 代码如下
  • import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.io.StreamTokenizer;
    import java.util.ArrayList;
    import java.util.List; public class Main { public static Integer[] dp(int[] arr, String s,int t,char ch) {
    List<Integer> ans = new ArrayList<>();
    if (arr[0] == t && s.charAt(0) == ch) {
    ans.add(1);
    } else {
    ans.add(0);
    }
    for (int i = 1; i < arr.length; i++) {
    if (arr[i] == t && s.charAt(i) == ch) {
    ans.add(ans.get(i - 1) + 1);
    } else {
    ans.add(ans.get(i - 1));
    }
    }
    return ans.toArray(new Integer[ans.size()]);
    } public static void main(String[] args) throws IOException {
    StreamTokenizer in = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
    in.nextToken();
    int n = (int) in.nval;
    int[] arr = new int[n];
    for (int i = 0; i < arr.length; i++) {
    in.nextToken();
    arr[i] = (int) in.nval;
    }
    in.nextToken();
    String s = in.sval;
    Integer[] mlist = build(s, 'M');
    Integer[] elist = build(s, 'E');
    Integer[] xlist = build(s, 'X'); Integer[] hm0 = dp(arr, s,0,'M');
    Integer[] hm1 = dp(arr, s,1,'M');
    Integer[] hm2 = dp(arr,s, 2,'M'); Integer[] hx0 = dp(arr, s,0,'X');
    Integer[] hx1 = dp(arr, s,1,'X');
    Integer[] hx2 = dp(arr,s, 2,'X'); long ans = 0;
    for (int i = 0; i < elist.length; i++) {
    int j = upperlound(mlist, elist[i]);
    int p = upperlound(xlist, elist[i]); if (j == 0) {
    continue;
    }
    if (p == xlist.length) {
    continue;
    }
    j = j - 1; int t = mlist[j]; int x0 = hm0[t];
    int x1 = hm1[t];
    int x2 = hm2[t]; int k = xlist[p]; int y0 = k > 0 ? hx0[n - 1] - hx0[k - 1] : hx0[n - 1];
    int y1 = k > 0 ? hx1[n - 1] - hx1[k - 1] : hx1[n - 1];
    int y2 = k > 0 ? hx2[n - 1] - hx2[k - 1] : hx2[n - 1]; int z = arr[elist[i]]; if (z == 2) {
    ans += 1l*x0*(y0 + y2 + 3 * y1);
    ans += 3l*x1*y0;
    ans += 1l* x2*y0;
    }
    else if( z == 1){
    ans += 1l*x0*(2*y0+2*y1+3*y2);
    ans += 2l*x1*y0;
    ans += 3l*x2*y0;
    }
    else{
    ans += 1l*x0*(y0+2*y1+y2);
    ans += 1l*x1*(2*y0+2*y1+3*y2);
    ans += 1l*x2*(y0+3*y1+y2);
    } } System.out.println(ans);
    } /**
    * @param arr
    * @param value
    * @return 》 value的第一个坐标位置,如果不存在,那么就是arr.length;
    */
    public static int upperlound(Integer[] arr, int value) {
    int low = 0;
    int high = arr.length;
    while (low < high) {
    int mid = low + (high - low) / 2;
    if (arr[mid] <= value) {
    low = mid + 1;
    } else {
    high = mid;
    }
    }
    return low;
    } public static Integer[] build(String str, char ch) {
    List<Integer> list = new ArrayList<>();
    for (int i = 0; i < str.length(); i++) {
    if (str.charAt(i) == ch) {
    list.add(i);
    }
    }
    return list.toArray(new Integer[list.size()]);
    } }

【atcoder beginner 308E - MEX】的更多相关文章

  1. 【AtCoder Beginner Contest 181】A~F题解

    越学越菜系列 于2020.11.2,我绿了(错乱) A - Heavy Rotation 签到题,奇数Black,偶数White. code: #include<bits/stdc++.h> ...

  2. 【AtCoder Beginner Contest 074 D】Restoring Road Network

    [链接]h在这里写链接 [题意] 给你任意两点之间的最短路. 让你求出原图. 或者输出原图不存在. 输出原图的边长总和的最小值. [题解] floyd算法. 先在原有的矩阵上. 做一遍floyd. 如 ...

  3. 【AtCoder Beginner Contest 074 C】Sugar Water

    [链接]h在这里写链接 [题意] 让你在杯子里加糖或加水. (4种操作类型) 糖或水之间有一定关系. 糖和水的总量也有限制. 问你糖水浓度的最大时,糖和糖水的量. [题解] 写个dfs就好. 每次有4 ...

  4. 【AtCoder Beginner Contest 074 B】Collecting Balls (Easy Version)

    [链接]h在这里写链接 [题意] 看懂题目之后就会发现是道大水题. [题解] 在这里写题解 [错的次数] 0 [反思] 在这了写反思 [代码] #include <bits/stdc++.h&g ...

  5. 【AtCoder Beginner Contest 074 A】Bichrome Cells

    [链接]h在这里写链接 [题意] 在这里写题意 [题解] 在这里写题解 [错的次数] 0 [反思] 在这了写反思 [代码] #include <bits/stdc++.h> using n ...

  6. 【AtCoder Regular Contest 082】Derangement

    [链接]点击打开链接 [题意] 在这里写题意 [题解] 贪心. 连续一块的p[i]==i的话,对答案的贡献就应该为(这个连续块的长度+1)/2; 长度为1的也正确. (也即两两相邻的互换位置.) [错 ...

  7. 【AtCoder ABC 075 D】Axis-Parallel Rectangle

    [链接] 我是链接,点我呀:) [题意] 让你找到一个各边和坐标轴平行的矩形.使得这个矩形包含至少K个点. 且这个矩形的面积最小. [题解] 把所有的"关键点""都找出来 ...

  8. 【AtCoder ABC 075 C】Bridge

    [链接] 我是链接,点我呀:) [题意] 让你求出桥的个数 [题解] 删掉这条边,然后看看1能不能到达其他所有的点就可以了 [代码] #include <bits/stdc++.h> us ...

  9. 【AtCoder ABC 075 B】Minesweeper

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 模拟,把#换成1 八个方向加一下就好. [代码] #include <bits/stdc++.h> using name ...

  10. 【AtCoder ABC 075 A】One out of Three

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 用map轻松搞定 [代码] #include <bits/stdc++.h> using namespace std; ...

随机推荐

  1. Exadata存储节点的CPU限制成功了没?

    上篇随笔谈到刷1/8 rack时,日志显示存储节点已经成功限制CPU的,可如果使用mpstat命令看貌似还是64 CPU,难道实际没有成功吗? [root@dbm08celadm03 ~]# mpst ...

  2. ASP.NET Core分布式项目实战(Consent 确认逻辑实现)--学习笔记

    任务22:Consent 确认逻辑实现 接下来,我们会在上一节的基础上添加两个按钮,同意和不同意,点击之后会把请求 post 到 ConsentController 处理,如果同意会通过 return ...

  3. .NET Core开发实战(第18课:日志框架:聊聊记日志的最佳姿势)--学习笔记(下)

    18 | 日志框架:聊聊记日志的最佳姿势 除了使用 CreateLogger 指定 logger 的名称,实际上还可以借助容器来构造 logger,通常情况下我们会定义自己的类 namespace L ...

  4. 开源.NetCore通用工具库Xmtool使用连载 - 散列算法篇

    [Github源码] <上一篇>详细介绍了Xmtool工具库中的加解密类库,今天我们继续为大家介绍其中的散列算法类库. 散列算法在某些特殊场景也可以当做加密方法使用:其特点是不可逆,同一内 ...

  5. 玩转 CMS2

    玩转 CMS2 上篇研究了样式.请求.evn.mock,感觉对效率的提升没有太明显作用. 比如某个工作需要2天,现在1天可以干完,这就是很大的提升. 提高效率的方法有代码复用.模块化.低代码工具. 目 ...

  6. 【OpenGL ES】绘制正方形

    1 前言 ​ [OpenGL ES]绘制三角形 中介绍了绘制三角形的方法,本文将介绍绘制正方形的方法. ​ OpenGL 以点.线段.三角形为图元,没有提供绘制正方形内部的接口.要绘制正方形内部,必须 ...

  7. Linux 下配置Oracle开机自动启动

    一./etc/oratab说明 直接使用cat 查看这个文件: gg1:/home/oracle> cat /etc/oratab # # This file is used by ORACLE ...

  8. Java并发编程实例--11.在线程组中处理未检查异常

    第8个例子讲了如何在线程中捕捉未检查异常,本例将介绍如何在线程组中处理未检查异常. Task.java package com.dylan.thread.ch1.c11.task; import ja ...

  9. docker 常用命令 快捷命令

    一.查询节点 docker ps -a 二.docker重启停止 systemctl restart docker systemctl stop docker docker restart * 三.一 ...

  10. Qt+ECharts开发笔记(一):ECharts介绍、下载和Qt调用ECharts基础柱状图Demo

    前言   使用Qt开发大数据可视化看板,基于Qt使用QWidget或者QML是很难达到ECharts大数据看板的效果,所以使用Qt来制作.   核心思想   每一个ECharts图表使用一个无边框的Q ...