AtCoder Beginner Contest 331 题解 A-E

news2025/1/21 3:04:31

A - Tomorrow

原题链接

题目描述
已知一年有M个月D天,求出第ymd天的后一天是哪一天。

思路:分类讨论

  • 分别讨论md的是否是最后一个月或者最后一天即可。
public static void solve() throws IOException {
    int n = readInt(), m = readInt();
    int a = readInt(), b = readInt(), c = readInt();
    if (c < m) {
        printWriter.println(a + " " + b + " " + (c + 1));
    } else {
        if (b == n) {
            printWriter.println((a + 1) + " "  + 1 + " " + 1);
        } else {
            printWriter.println(a + " " + (b + 1) + " " + 1);
        }
    }
}

B - Buy One Carton of Milk

原题链接

题目描述
一家超市正在销售鸡蛋。一包 6 6 6个鸡蛋售价 S S S日元,一包 8 8 8个鸡蛋售价 M M M日元,一包 12 12 12个鸡蛋售价 L L L日元。你可以购买任意数量的每包鸡蛋,求至少购买 N N N个鸡蛋所需的最小金额。

思路:枚举

  • 分别枚举每包鸡蛋购买的数量,求出最小值。
public static void solve() throws IOException {
    int n = readInt();
    int a = readInt(), b = readInt(), c = readInt();
    int min = Integer.MAX_VALUE;
    for (int i = 0; i <= n; i++) {
        for (int j = 0; j <= n; j++) {
            for (int k = 0; k <= n; k++) {
                if (i * 6 + j * 8 + k * 12 >= n) {
                    min = Math.min(min, i * a + b * j + c * k);
                }
            }
        }
    }
    printWriter.println(min);
}

C - Sum of Numbers Greater Than Me

原题链接

题目描述
给你一个长度为 N N N 的序列 A = ( A 1 , … , A N ) A=(A_1,\ldots,A_N) A=(A1,,AN)。对于每个 i = 1 , … , N i=1,\ldots,N i=1,,N,求出 A A A 中所有大于 A i A_i Ai 的元素之和。

思路:排序+前缀和+二分

  • 对于每个 A i A_i Ai,求出它在排序好的数组中,后面比它大的数的和即可,具体看代码注释。
public static void solve() throws IOException {
    int n = readInt();
    int[] arr = new int[n + 1];
    int[] arr2 = new int[n + 1];
    for (int i = 1; i <= n; i++) {
        arr[i] = readInt();
        arr2[i] = arr[i];
    }
    Arrays.sort(arr2, 1, n + 1);
    long[] pre = new long[n + 1];
    for (int i = 1; i <= n; i++) {
        pre[i] = pre[i - 1] + arr2[i];// 前缀和
    }
    for (int i = 1; i <= n; i++) {
        int l = 0, r = n + 1;
        // 二分找到 arr[i]在 arr2中最后一次出现的位置
        while (l + 1 < r) {
            int mid = l + r >> 1;
            if (arr2[mid] <= arr[i]) {
                l = mid;
            } else {
                r = mid;
            }
        }
        if (l == 0 || r == n + 1) {// arr[i]已经最大
            printWriter.print(0 + " ");
        } else {
            printWriter.print((pre[n] - pre[l]) + " ");
        }
    }
}

D - Tile Pattern

原题链接

题目描述
有一个无穷大的正方形网格。网格中的每个方格都是黑色或白色的。方格 ( i , j ) (i, j) (i,j) 的颜色由字符 P [ i   m o d   N ] [ j   m o d   N ] P[i \bmod N][j \bmod N] P[imodN][jmodN] 表示,其中 B 表示黑色,W 表示白色。这里, a   m o d   b a \bmod b amodb表示 a a a 除以 b b b 的余数。然后给出 Q Q Q个查询, 每个查询给出四个整数 A , B , C , D A, B, C, D A,B,C,D,要求你找出以 ( A , B ) (A, B) (A,B)为左上角, ( C , D ) (C, D) (C,D)为右下角的矩形区域中包含的黑色方格的个数

思路:前缀和

  • 先根据已给出的 n × n n \times n n×n 的网格计算出前缀和。
  • 然后可以根据 A , B , C , D A, B, C, D A,B,C,D将图形分为四个区域,且让四区域的左上角都为 ( 0 , 0 ) (0, 0) (0,0),右下角分别为 ( A − 1 , B − 1 ) , ( A − 1 , D ) , ( C , B − 1 ) , ( C , D ) (A-1,B-1),(A-1,D),(C,B-1),(C,D) (A1,B1),(A1,D),(C,B1),(C,D)
    在这里插入图片描述
  • 分好区域后,又可以将每个区域分为四部分。假设一个区域有 r r r c c c 列,那么 ①左上角有 ( r / n ) ∗ ( c / n ) (r / n) * (c / n) (r/n)(c/n) n ∗ n n * n nn大小的网格,②右上角有 ( r / n ) (r/n) (r/n) n ∗ ( c % n ) n * (c \% n) n(c%n)大小的网格,③左下角有 ( c / n ) (c/n) (c/n) ( r % n ) ∗ n (r \% n) * n (r%n)n大小的网格,④右下角有一个 ( r % n ) ∗ ( c % n ) (r \% n) * (c \% n) (r%n)(c%n)大小的网格。
  • 最后再通过前缀和的方式得到 ( A , B ) (A, B) (A,B)为左上角, ( C , D ) (C, D) (C,D)为右下角的矩形区域中包含的黑色方格的个数。
static int n, q;
static long[][] pre;

public static void solve() throws IOException {
    n = readInt(); q = readInt();
    pre = new long[n + 1][n + 1];
    for (int i = 1; i <= n; i++) {
        String s = (" " + readString());
        for (int j = 1; j <= n; j++) {
            if (s.charAt(j) == 'B') pre[i][j] = 1;
        }
    }
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= n; j++) {
            pre[i][j] += pre[i - 1][j] + pre[i][j - 1] - pre[i - 1][j - 1];
        }
    }

    while (q-- > 0) {
        int a = readInt() + 1, b = readInt() + 1;// 左上角
        int c = readInt() + 1, d = readInt() + 1;// 右下角
        printWriter.println(calc(c, d) - calc(c, b - 1) - calc(a - 1, d) + calc(a - 1, b - 1));
    }
}

public static long calc(int r, int c) {
    long sum = 0;
    sum += 1l * (r / n) * (c / n) * pre[n][n];// 左上
    sum += 1l * (r / n) * pre[n][c % n];// 右上
    sum += 1l * (c / n) * pre[r % n][n];// 左下
    sum += 1l * pre[r % n][c % n];// 右下
    return sum;
}

E - Set Meal

原题链接

题目描述
一家餐厅出售的饭菜包括一道主菜和一道配菜。 主菜有 N N N 种,主菜 i i i 的价格为 a i a_i ai 日元。 配菜有 M M M 种,配菜 i i i 的价格为 b i b_i bi 日元。套餐由一道主菜和一道配菜组成,价格为所选主菜和配菜价格的总和。
但是餐厅不提供 L L L 对不同的由主菜 c i c_i ci 和配菜 d i d_i di 组成的套餐。也就是说,餐厅只提供了 N ∗ M − L N * M - L NML 份套餐。请你求出可以提供的最贵套餐的价格

思路:排序+多路归并

  • 将主菜和配菜降序排序,再构建一个大顶堆,实现多路归并。
  • 先让每个主菜与第一个配菜组成套餐,即入队。
  • 寻找答案:如果堆顶元素可以组成套餐,那么输出答案,否则让该主菜和下一个配菜组成套餐,入队。
public static void solve() throws IOException {
    int n = readInt(), m = readInt(), L = readInt();
    Pair[] a = new Pair[n], b = new Pair[m];
    for (int i = 0; i < n; i++) a[i] = new Pair(i, readInt());
    for (int i = 0; i < m; i++) b[i] = new Pair(i, readInt());
    Arrays.sort(a, (p, q) -> q.second - p.second);// 降序
    Arrays.sort(b, (p, q) -> q.second - p.second);
    Map<Integer, Set<Integer>> map = new HashMap<>();// 不提供的套餐
    for (int i = 0; i < L; i++) {
        int c = readInt() - 1, d = readInt() - 1;
        Set<Integer> set = map.getOrDefault(c, new HashSet<>());
        set.add(d);
        map.put(c, set);
    }
	// 大顶堆,按照 a[i] + b[j]降序排序
    PriorityQueue<int[]> deque = new PriorityQueue<>((p, q) -> {
        return a[q[0]].second + b[q[1]].second - (a[p[0]].second + b[p[1]].second);
    });
    for (int i = 0; i < n; i++) {
        deque.offer(new int[]{i, 0});
    }
    // 注意入队时,使用排序好的数组下标
    // 计算时,使用原数组的下标
    while (deque.size() > 0) {
        int[] t = deque.poll();
        if (!map.getOrDefault(a[t[0]].first, new HashSet<>()).contains(b[t[1]].first)) {
            printWriter.println(a[t[0]].second + b[t[1]].second);
            return;
        }
        if (t[1] + 1 < m) {// 下一个配菜
            deque.offer(new int[]{t[0], t[1] + 1});
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1280079.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringSecurity工作原理

实现功能就是继承这几个对应功能的类。 大概工作流程 Spring Security 的过滤器&#xff08;Filters&#xff09;和拦截器&#xff08;Interceptors&#xff09;是 Spring Security 框架中用于保护 web 应用安全的重要组件。它们在处理 HTTP 请求时扮演不同的角色&#xff0c…

Wireshark抓包分析RTMP协议时,出现Unknown问题

进行rtmp推流时&#xff0c;使用wireshark抓包&#xff0c;发现部分包显示Unknown 解决方法&#xff1a; 编辑 -> 首选项 -> Protocols -> RTMPT&#xff0c;这里Maximum packet size默认是32768 将该值调大&#xff0c;比如调成1048576&#xff0c;即可解决该问题。…

GitHub Actions 之自动化发布 Maven 项目

开发开源数据中台项目 datacap 时&#xff0c;之前发布版本都是通过在本地编译并部署到 maven 中央仓库中&#xff0c;这样就导致是非自动化工程&#xff0c;于是通过搜索发现 samuelmeuli/action-maven-publish 这个 github 自动化工具可以帮助我们来做这些事情&#xff0c;本…

第 374 场 LeetCode 周赛题解

A 找出峰值 枚举 class Solution { public:vector<int> findPeaks(vector<int> &mountain) {int n mountain.size();vector<int> res;for (int i 1; i < n - 1; i)if (mountain[i] > mountain[i - 1] && mountain[i] > mountain[i 1…

基于搜索协议实现工业设备升级

目录 1、背景引入 2、技术分析 3、过程概述 4、服务器端流程 5、客户端流程 6、效果展示 7、源码 7.1 master&#xff08;主控&#xff09; 7.2 device&#xff08;设备&#xff09; 8、注意事项 1、背景引入 在工业生产中&#xff0c;设备的升级和维护是非常重要的…

JavaScript学习-1

01 基础用法 //index.html <body><!-- 行内JS --><button type"button" onclick"alert(hello)">按钮</button><!--内部JS--><script type"text/javascript">alert("你好");</script><…

Unity C++交互

一、设置Dll输出。 两种方式&#xff1a; 第一&#xff1a;直接创建动态链接库工程第二&#xff1a;创建的是可执行程序&#xff0c;在visual studio&#xff0c;右键项目->属性(由exe改成dll) 二、生成Dll 根据选项Release或Debug&#xff0c;运行完上面的生成解决方案后…

计网Lesson6 - IP 地址分类管理

文章目录 1. I P IP IP 地址定义2. I P v 4 IPv4 IPv4 的表示方法2.1 I P v 4 IPv4 IPv4 的分类编址法2.2 I P v 4 IPv4 IPv4 的划分子网法2.2.1 如何划分子网2.2.2 如何确定子网的借位数2.2.3 总结2.2.4 题目练习 2.3 I P v 4 IPv4 IPv4 的无分类编址法 1. I P IP IP 地…

kafka3.6.0部署

部署zk https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.9.1/apache-zookeeper-3.9.1.tar.gz tar -xf apache-zookeeper-3.9.1.tar.gz -C /apps cd /apps/ && ln -s apache-zookeeper-3.9.1 zookeeper 修改配置bash grep -vE ^$|^# conf/zo…

代码随想录算法训练营第四十一天 _ 动态规划_343. 整数拆分、96.不同的二叉搜索树、01背包问题。

学习目标&#xff1a; 动态规划五部曲&#xff1a; ① 确定dp[i]的含义 ② 求递推公式 ③ dp数组如何初始化 ④ 确定遍历顺序 ⑤ 打印递归数组 ---- 调试 引用自代码随想录&#xff01; 60天训练营打卡计划&#xff01; 学习内容&#xff1a; 343. 整数拆分 动态规划五步曲&…

【接口测试】Apifox实用技巧干货分享

前言 不知道有多少人和我有着这样相似的经历&#xff1a;从写程序只要不报错就不测试&#x1f60a;&#xff0c;到写了程序若是有bug就debug甚至写单元测试&#xff0c;然后到了真实开发场景&#xff0c;大哥和你说&#xff0c;你负责的功能模块的所有接口写完要测试一遍无误在…

python——进程常用功能

Python的multiprocessing模块提供了强大的并行处理能力&#xff0c;以下是几个功能的详细解释&#xff1a; join(): 在multiprocessing中&#xff0c;join方法用于阻塞主进程直到指定的进程终止。这对于确保所有子进程在程序结束前完成其工作是很有用的。deamon(): 在multipro…

16.字符串处理函数——字符串长度函数

文章目录 前言一、题目描述 二、解题 程序运行代码 总结 前言 本系列为字符串处理函数编程题&#xff0c;点滴成长&#xff0c;一起逆袭。 一、题目描述 二、解题 程序运行代码 #include<stdio.h> #include<string.h> int main() {char str[ ]"0123\0456…

根据关键词写作文章的软件,根据标题写作文章的工具

在当今信息化时代&#xff0c;人工智能技术的飞速发展&#xff0c;智能AI写作工具逐渐成为文案创作者的得力助手。这些工具不仅能够根据标题迅速生成文章&#xff0c;而且在提高创作效率的同时&#xff0c;也为我们节省了大量时间和精力。 人工智能的基本原理&#xff1a;人工智…

如何查看Microsoft Office 使用期限

1.进入到 Office 软件的安装目录&#xff08;******\Microsoft Office\Office&#xff09; ## 以管理员身份打开 Windows PowerShell输入以下命令&#xff0c;回车 cscript ospp.vbs /dstatusREMAINING GRACE 一行表示激活剩余天数&#xff08;括号内是换算成的剩余分钟数…

15.字符串处理函数——字符串连接函数

文章目录 前言一、题目描述 二、解题 程序运行代码 总结 前言 本系列为字符串处理函数编程题&#xff0c;点滴成长&#xff0c;一起逆袭。 一、题目描述 二、解题 程序运行代码 #include<stdio.h> #include<string.h> int main() {char dest[20] "12345…

【Linux】第二十五站:深入理解文件系统

文章目录 一、前言二、认识硬件----磁盘1.基本介绍2.磁盘的存储构成3.磁盘的逻辑结构4.回归到硬件 三、文件系统1.划分2.Block group(1)Data blocks(2)inode Table(3)Block Bitmap(4)inode Bitmap(5)Group Descriptor Table(GDT)(6)Super Block 3.总结4.一些其他问题5.如何理解…

音视频的功耗优化

前言 在应用中&#xff0c;录制与音视频模块往往是高耗能的模块&#xff0c;设备容易发热&#xff0c;影响体验。 什么是功耗优化 手机有多个耗电模块&#xff0c; SOC(CPU&#xff0c;GPU&#xff0c;DDR)&#xff0c;Display&#xff0c;Audio&#xff0c;Video&#xff0…

loguru的简单使用

详细使用&#xff1a;Table of contents — loguru documentation 【1】日志的级别 日志级别默认分为6种 1、NOTSET (0)2、DEBUG (1)3、INFO (2)4、WARNING (3)5、ERROR (4)6、CRITICAL (5) logging 执行时输出大于等于设置的日志级别的日志信息&#xff0c;如设置日…

zemax之初级像差理论与像差校正——慧差

通过上节介绍&#xff0c;我们已经知道在轴上视场产生的球差是旋转对称的像差。在进行光学系统设计时&#xff0c;同时需要保证轴上物点和轴外物点的成像质量。轴外物点成像时会引入轴外像差&#xff0c;即轴外视场产生的慧差&#xff08;coma aberration&#xff09; 1.慧差概…