Codeforces Round 971 (Div. 4) ABCD题详细题解(C++,Python)

news2024/12/26 23:40:26

前言:

        本文为Codeforces Round 971 (Div. 4) ABCD题的题解,包含C++,Python语言描述,觉得有帮助或者写的不错可以点个赞

        比赛打了没一半突然unrated了就不是很想继续写了,早起写个题解,下午再更新后面EFG1的,G2有点难应该写不出来,EFG1都比较常规。

        (之前的div3也没复盘,哎真菜)

目录

题A:

题目大意和解题思路:

代码(C++):

代码(Python):

题B:

题目大意和解题思路:

代码(C++):

代码(Python):

题C:

题目大意和解题思路:

代码(C++):

代码(Python):

题D:

题目大意和解题思路:

代码(C++):

代码(Python):


题A:

Problem - A - Codeforces

题目大意和解题思路:

给定两个整数 a 和 b (a ≤ b)。在所有可能的整数值 c (a ≤ c ≤ b) 中,找到 (c-a) + (b-c) 的最小值。

弱智题

代码(C++):

int main() {
    #define int long long
    std::ios::sync_with_stdio(0);
    std::cin.tie(0);
    int tt;
    std::cin >> tt;
    
    while (tt--) {
        int a, b;
        std::cin >> a >> b;
        std::cout << b - a << "\n";
    }
}

代码(Python):

def main():
    tt = int(input())
    result = []

    for _ in range(tt):
        a, b = map(int, input().split())
        result.append(b - a)
        
    for res in result:
        print(res)

题B:

Problem - B - Codeforces

题目大意和解题思路:

你的谱面布局由 n 行和 4 列组成。因为底部的音符更接近,所以你会先处理最底部的行,最后处理最上面的行。每一行都会包含一个音符,用 '#' 表示。

对于每个音符 1, 2, ..., n,按照处理顺序,输出该音符出现的列。

从最下面开始,查找#的位置即可,注意输出的是位置不是下标

代码(C++):

int main() {
    #define int long long
    std::ios::sync_with_stdio(0);
    std::cin.tie(0);
    int tt;
    std::cin >> tt;
    
    while (tt--) {
        int n;
        std::cin >> n;
        std::vector<std::string> A(n);
        for (int i = 0; i < n; i++) {
            std::cin >> A[i];
        }
        for (int i = n - 1; i >= 0; i--) {
            std::string s = A[i];
            for (int j = 0; j < 4; j++) {
                if (s[j] == '#') {
                    std::cout << j + 1 << " ";
                    break;
                }
            }
        }
        std::cout << "\n";
    }
    
}

代码(Python):

def main():
    tt = int(input())
    result = []

    for _ in range(tt):
        n = int(input())
        A = [""] * n
        for i in range(n):
            A[i] = input()
        res = []
        for i in range(n - 1, -1, -1):
            s = A[i]
            for j in range(4):
                if s[j] == "#":
                    res.append(j + 1)
                    break
        result.append(res)

    for res in result:
        print(*res)

题C:

Problem - C - Codeforces

题目大意和解题思路:

Freya 正在二维坐标平面上旅行。她现在位于点 (0,0) 并想到达点 (x,y)。在一次移动中,她选择一个整数 d,满足 0 ≤ d ≤ k,然后向她正在面对的方向跳 d 个格子。

最初,她面向正 x 方向。在每次移动后,她会在面向正 x 方向和正 y 方向之间交替(即,她的第二次移动会面向正 y 方向,第三次移动会面向正 x 方向,依此类推)。

要到达点 (x,y),她至少需要执行多少次移动?

有趣的小学数学题,卡了我一段时间

首先要确定的是,刚开始是向x方向移动,然后k是最大距离,移动距离可以为0,但是要计数

虽然是每次交替,但是可以这么想:,先把短的一边走完,再走长的一边,然后短的那一边移动距离0即可,那么最终答案就为长的一边的移动次数乘以2

求出x方向的最小移动次数d_x,y方向的最小移动次数d_y

求出最大的那一个乘以2即为答案,注意若是d_x * 2最大,那么需要-1,因为是先从x方向进行移动的

代码(C++):

int main() {
    #define int long long
    std::ios::sync_with_stdio(0);
    std::cin.tie(0);
    int tt;
    std::cin >> tt;
    
    while (tt--) {
        int x, y, k;
        std::cin >> x >> y >> k;
        int d_x = (x + k - 1) / k;
        int d_y = (y + k - 1) / k;
        int res = std::max(d_x * 2 - 1, d_y * 2);
        std::cout << res << "\n";
    }
}

代码(Python):

def main():
    tt = int(input())
    result = []

    for _ in range(tt):
        x, y, k = map(int, input().split())
        d_x = (x + k - 1) // k
        d_y = (y + k - 1) // k
        res = max(d_x * 2 - 1, d_y * 2)
        result.append(res)
        
    for res in result:
        print(res)

题D:

Problem - D - Codeforces

题目大意和解题思路:

题目意思就是说,给你一些整数点,其中纵坐标y的值为0和1,然后让你求从这些点中选三个点组成直角三角形,一共有多少种选法

当 y 只取0和1的时候,可以理解成一个平行线,上面取三点,组成直角三角形

那么只有两种情况,一种是两点连成的直线垂直于平行线(也就是纵坐标相等的两个点),加上两条平行线上面任意一点即可组成直角三角形

另外一种就是中间一个点,左边两个点..组成等腰直角三角形,如下图所示:长度必须满足下面情况


代码实现的话,统计纵坐标相等两点的情况,每种情况都会使得答案加上n - 2(点的个数-2)

第二种情况就查看是否对于每一个横坐标x,是否在对面平行线上x - 1和x + 1位置有点即可

我这里用哈希表暴力解

代码(C++):

int main() {
    #define int long long
    std::ios::sync_with_stdio(0);
    std::cin.tie(0);
    int tt;
    std::cin >> tt;
    
    while (tt--) {
        int n;
        std::cin >> n;
        std::unordered_map<int, int> cnt0, cnt1;
        for (int i = 0; i < n; i++) {
            int x, y;
            std::cin >> x >> y;
            if (y == 0) {
                cnt0[x]++;
            } else {
                cnt1[x]++;
            }
        }
        int res = 0;
        for (auto& p : cnt0) {
            int x = p.first;
            if (cnt1.count(x)) {
                res += (cnt1.size() + cnt0.size() - 2);
            }
        }
        for (auto& p : cnt0) {
            int x = p.first;
            if (cnt1.count(x - 1) && cnt1.count(x + 1)) {
                res++;
            }
        }
        for (auto& p : cnt1) {
            int x = p.first;
            if (cnt0.count(x - 1) && cnt0.count(x + 1)) {
                res++;
            }
        }
        std::cout << res << "\n";
    }
}

代码(Python):

def main():
    tt = int(input())
    result = []

    for _ in range(tt):
        n = int(input())
        cnt0 = defaultdict(int)
        cnt1 = defaultdict(int)
        
        for _ in range(n):
            x, y = map(int, input().split())
            if y == 0:
                cnt0[x] += 1
            else:
                cnt1[x] += 1
        
        res = sum((len(cnt1) + len(cnt0) - 2) for x in cnt0 if x in cnt1)
        res += sum(1 for x in cnt0 if (x - 1 in cnt1 and x + 1 in cnt1))
        res += sum(1 for x in cnt1 if (x - 1 in cnt0 and x + 1 in cnt0))
        
        result.append(res)
    for res in result:
        print(res)

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

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

相关文章

桌球棋牌计时计费管理系统软件 可以语音报价停电可以恢复上次时间状态 佳易王计时计费管理系统操作教程

一、前言 桌球棋牌计时计费管理系统软件 可以语音报价停电可以恢复上次时间状态 佳易王计时计费管理系统操作教程 1、佳易王桌球计时计费软件&#xff0c;在使用中如遇到突然停电&#xff0c;再次打开软件的时候&#xff0c;可以点击 恢复上次状态按钮&#xff0c;时间可以恢…

CRIO与Windows下LabVIEW开发对比

LabVIEW在CRIO和Windows平台上开发时&#xff0c;尽管同属于一个编程环境&#xff0c;但在硬件架构、实时性能、模块化设计等方面存在显著差异。CRIO系统通常应用于工业自动化和嵌入式控制&#xff0c;具有实时操作系统支持和强大的I/O扩展能力&#xff1b;而Windows系统则更适…

【word导出带图片】使用docxtemplater导出word,通知书形式的word

一、demo-导出的的 二、代码操作 1、页面呈现 项目要求&#xff0c;所以页面和导出来的word模版一致 2、js代码【直接展示点击导出的js代码】 使用插件【先下载这五个插件&#xff0c;然后页面引入插件】 import docxtemplater from docxtemplater import PizZip from pizzip …

生成密码c

需求 目前需要实现生成8-12位密码&#xff0c;密码要求至少包含一位数字&#xff0c;一位大写字母&#xff0c;一位小写字母&#xff0c;一位特殊字符。特殊字符仅包含&#xff08;“”&#xff0c;“&#xff01;”&#xff0c;“_”&#xff09; 需求分析 可知我们需要1个…

SVD的diffusers版本代码解析

https://zhuanlan.zhihu.com/p/701223363https://zhuanlan.zhihu.com/p/701223363ComfyUI中SVD 1.1:文生图,图生图,LCM应用 - 腾讯云开发者社区-腾讯云

[工具使用]git

git fetch 获取远程仓库内容&#xff0c;但未合入本地仓库&#xff1b; git rebase 获取远程仓库内容&#xff0c;并更改基地合入本地仓库&#xff1b; 将master分支的内容合入feature分支&#xff1a; 当在feature分支上执行git rebase master时&#xff0c;git会从master…

如何在不重装的前提下,将1TB的硬盘克隆到500GB的固态硬盘?

借助傲梅分区助手&#xff0c;你能够在Windows 11、10、8、7中轻松的将1TB硬盘克隆到500GB固态硬盘。并且无需重新安装系统&#xff0c;即可轻松实现1TB机械硬盘升级至固态硬盘。 问&#xff1a;可以克隆到较小的固态硬盘吗&#xff1f; “大家下午好&#xff01;我刚买了一块…

《数字信号处理》学习03-矩形序列,实指数序列和复指数序列

目录 一&#xff0c;矩形序列 1&#xff0c;由单位阶跃序列组成 2&#xff0c;由单位冲击序列组成 二&#xff0c;实指数序列 三&#xff0c;复指数序列 这篇文章着重学习&#xff1a;矩形序列&#xff0c;实指数序列和复指数序列。其它序列都比较简单&#xff0c;这里不再…

计算机毕业设计PySpark深度学习动漫推荐系统 动漫视频推荐系统 机器学习 协同过滤推荐算法 bilibili动漫爬虫 数据可视化 数据分析 大数据毕业设计

本推荐系统采用的是分层模型设计思想&#xff0c;第一层为前端页面模型设计&#xff0c;注重为实现页面的展示效果&#xff0c;主用的编程语言为JavaScript,和前端主流框架bootstrap。 第二层为后端模型设计&#xff0c;编程语言选了简单易懂的python&#xff0c;用Django作为后…

如何远程连接其他电脑?两种常用方法!

在过去&#xff0c;远程控制仅限于那些擅长计算机专业技术的少数人。然而&#xff0c;随着科学技术的不断发展&#xff0c;越来越多的人可以通过各种远程控制软件实现对其他电脑的远程操作。如今&#xff0c;对于普通电脑用户来说&#xff0c;使用自己的电脑远程控制另一台电脑…

前端框架有哪些?

成长路上不孤单&#x1f60a;【14后&#xff0c;C爱好者&#xff0c;持续分享所学&#xff0c;如有需要欢迎收藏转发&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#xff01;&#xff01;&#xff01;&#xff01;&#xff…

【图论】Dijkstra算法求最短路

一、Dijkstra算法简介 Dijkstra算法是由河南荷兰计算机科学家狄克斯特拉(Dijkstra)于1959年提出的,因此又叫狄克斯特拉算法。 二、初识Dijkstra算法 在使用Dijkstra算法求最短路时&#xff0c;需要用到三个辅助数组&#xff1a; v i s x vis_x visx​&#xff1a;布尔数组&…

PostgreSQL技术内幕8:PostgreSQL查询执行器

0.简介 执行器是查询编译和存储引擎之间的连接模块&#xff0c;其负责将优化器输出的执行计划&#xff0c;进行初始化、执行&#xff0c;访问存储引擎并获得最终结果返回&#xff0c;本章主要介绍PG的执行器模型和其执行流程。 执行器的处理模型 常见的执行器的处理模型包含…

海南云亿商务咨询有限公司抖音电商服务的可靠之选

在这个短视频与直播电商风起云涌的时代&#xff0c;抖音作为其中的佼佼者&#xff0c;正引领着新一轮的消费潮流。而在这片充满机遇与挑战的电商蓝海中&#xff0c;海南云亿商务咨询有限公司犹如一颗璀璨新星&#xff0c;凭借其专业的服务与独到的策略&#xff0c;在抖音电商领…

缺失值插补解释:六种插补方法?

目录 一、说明 二、什么是缺失值&#xff0c;为什么会出现缺失值&#xff1f; 2.1 什么是缺失值&#xff1f; 2.2 为什么会出现缺失值&#xff1f; 2.3 缺失数据类型 2.4 为什么要关注缺失值&#xff1f; 三、数据集 四、缺失数据的插值方式 4.1 方法 1&#xff1a;List-wise D…

通过Python库ydata-profiling生成数据分析报告

一&#xff1a;ydata-profiling库的介绍 ydata-profiling是一个强大的 Python 库&#xff0c;它为 Pandas DataFrame 提供了快速的探索性数据分析&#xff08;EDA&#xff09;。它能够自动生成包含详细统计信息的交互式 HTML 报告&#xff0c;使得数据分析变得更加直观和便捷。…

设计模式 -- 中介者模式(Mediator Pattern)

1 问题引出 1.1 智能家庭项 智能家庭包括各种设备&#xff0c;闹钟、咖啡机、电视机、窗帘 等主人要看电视时&#xff0c;各个设备可以协同工作&#xff0c;自动完成看电视的准备工作&#xff0c;比如流程为&#xff1a;闹铃响起->咖啡机开始做咖啡->窗帘自动落下->电…

idea插件【1】Smart Tomcat

一、简介 在开发过程中除了springboot项目支持jar运行&#xff0c;很多场景下需要使用到tomcat外置服务部署&#xff0c;此时我们可以使用idea插件Smart Tomcat &#xff08;Smart Tomcat 插件是一个用于简化与 Tomcat 服务器交互的工具&#xff0c;它提供了一些额外的功能来增…

TCP协议相关特性

TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是互联网传输层协议之一&#xff0c;也是 TCP/IP 协议簇的核心协议。它的作用是在 IP 网络上提供可靠的、面向连接的通信。 TCP基本特点: 有链接,可靠传输, 面向字节流 ,全双工 TCP协议段格…

掌握盈利新技能:网格交易法分享

交易策略对于交易成功至关重要。一个有效的策略可以帮助你在市场中轻松获得盈利&#xff0c;而一个不恰当的策略就可能导致不少损失。今天&#xff0c;我们将来探讨网格交易法&#xff0c;这是一种特别适合震荡市场的交易策略。 什么是网格交易法&#xff1f; 网格交易法&#…