【洛谷 P8668】[蓝桥杯 2018 省 B] 螺旋折线 题解(数学+平面几何)

news2024/9/23 11:27:54

[蓝桥杯 2018 省 B] 螺旋折线

题目描述

如图所示的螺旋折线经过平面上所有整点恰好一次。

对于整点 ( X , Y ) (X, Y) (X,Y),我们定义它到原点的距离 dis ( X , Y ) \text{dis}(X, Y) dis(X,Y) 是从原点到 ( X , Y ) (X, Y) (X,Y) 的螺旋折线段的长度。

例如 dis ( 0 , 1 ) = 3 \text{dis}(0, 1)=3 dis(0,1)=3 dis ( − 2 , − 1 ) = 9 \text{dis}(-2, -1)=9 dis(2,1)=9

给出整点坐标 ( X , Y ) (X, Y) (X,Y),你能计算出 dis ( X , Y ) \text{dis}(X, Y) dis(X,Y) 吗?

输入格式

X X X Y Y Y

输出格式

输出 dis ( X , Y ) \text{dis}(X, Y) dis(X,Y)

样例 #1

样例输入 #1

0 1

样例输出 #1

3

提示

对于 40 % 40\% 40%的数据, − 1000 ≤ X , Y ≤ 1000 -1000\le X,Y\le 1000 1000X,Y1000

对于 70 % 70\% 70% 的数据, − 1 0 5 ≤ X , Y ≤ 1 0 5 -10^5\le X,Y \le 10^5 105X,Y105

对于 100 % 100\% 100% 的数据, − 1 0 9 ≤ X , Y ≤ 1 0 9 -10^9\le X,Y \le 10^9 109X,Y109


思路

暴力模拟会超时,不妨想想其他办法。

函数d(int t)计算从原点到点(-t, t)的螺旋折线距离,使用等差数列求和公式2t * (2t + 1) * 2 / 2

函数dis(int x, int y)是主要的计算函数,根据输入的坐标点(x, y),计算出螺旋折线距离。

观察到有三条分界线: y = x y = x y=x y = − x y=-x y=x y = x + 1 y=x+1 y=x+1 将图形分为四个部分。可以对每个区域分类讨论,通过从原点到点(-t, t)的螺旋折线距离,换算出从原点到任意点(x, y)的螺旋折线距离。

  • 当点位于左侧区域,并且满足条件 x ≥ 0 x \geq 0 x0 − x ≤ y -x \leq y xy y < x y < x y<x时,此时的螺旋折线距离可以通过公式 d ( t ) + 3 ∗ t − y d(t) + 3 * t - y d(t)+3ty计算,其中 t = x t = x t=x

  • 当点位于上侧区域,并且满足条件 y > 0 y > 0 y>0 − y < x -y < x y<x x ≤ y x \leq y xy时,此时的螺旋折线距离可以通过公式 d ( t ) + t + x d(t) + t + x d(t)+t+x计算,其中 t = y t = y t=y

  • 当点位于右侧区域,并且满足条件 x < 0 x < 0 x<0 x + 1 < y x + 1 < y x+1<y y ≤ − x y \leq -x yx时,此时的螺旋折线距离可以通过公式 d ( t ) − t + y d(t) - t + y d(t)t+y计算,其中 t = − x t = -x t=x

  • 当点位于下侧区域,此时的螺旋折线距离可以通过公式 d ( t ) − 3 ∗ t − x + 1 d(t) - 3 * t - x + 1 d(t)3tx+1计算,其中 t = − y + 1 t = -y + 1 t=y+1

main函数中,使用cin从输入中读取坐标点(x, y),然后调用dis(int x, int y)计算螺旋折线距离,并使用cout输出结果。

注意

对于 100 % 100\% 100% 的数据, − 1 0 9 ≤ X , Y ≤ 1 0 9 -10^9\le X,Y \le 10^9 109X,Y109。dis 可能会超出 int 的范围。需要开 long long,否则无法通过部分测试点。


AC代码

#include <algorithm>
#include <iostream>
#define mp make_pair
#define AUTHOR "HEX9CF"
using namespace std;
using ll = long long;

const int N = 1e6 + 7;
const int INF = 0x3f3f3f3f;
const ll MOD = 1e9 + 7;

// 从原点到(-t, t)
ll d(int t) {
	// 2t * (2t + 1) * 2 / 2
	return (1ll * 2 * t * (2 * t - 1));
}

ll dis(int x, int y) {
	if (x >= 0 && -x <= y && y < x) {
		// 右
		int t = x;
		// d + 2t + (t - y)
		return (1ll * d(t) + 3 * t - y);
	} else if (y > 0 && -y < x && x <= y) {
		// 上
		int t = y;
		// d + (t - x)
		return (1ll * d(t) + t + x);
	} else if (x < 0 && x + 1 < y && y <= -x) {
		// 左
		int t = -x;
		// d - (t - y)
		return (1ll * d(t) - t + y);
	} else {
		// 下
		int t = -y + 1;
		// d - (2t - 1) - (x + t)
		return (1ll * d(t) - 3 * t - x + 1);
	}
}

int main() {
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);

	int x, y;
	cin >> x >> y;
	cout << dis(x, y) << "\n";

	return 0;
}

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

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

相关文章

武汉灰京文化:手机游戏行业创新与机遇引领着无限潜力的繁荣

近年来&#xff0c;手机游戏行业迎来了前所未有的繁荣&#xff0c;这主要得益于新技术的飞速发展和硬件的不断升级。市场研究机构预测&#xff0c;到2025年&#xff0c;全球手机游戏市场将超过2000亿美元。这一惊人的增长数据充分体现了手机游戏行业的活力和无限潜力。手机游戏…

appium2的一些配置

appium-desktop不再维护之后&#xff0c;需要使用appium2。 1、安装appium2 命令行输入npm i -g appium。安装之后输入appium或者appium-server即可启动appium 2、安装安卓/ios的驱动 安卓&#xff1a;appium driver install uiautomator2 iOS&#xff1a;appium driver i…

21 easy 1. 两数之和

//给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 // // 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。 // // 你可以…

代码随想录 回溯算法-棋盘问题

目录 51.N皇后 37.解数独 51.N皇后 51. N 皇后 困难 按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 给你一个整数 n &…

GESP5级T1真题 [202309] 因数分解——O(sqrt(n))的时间复杂度,值得一看

描述 每个正整数都可以分解成素数的乘积&#xff0c;例如&#xff1a;62*3、2022 *5 现在&#xff0c;给定一个正整数N&#xff0c;请按要求输出它的因数分解式。 输入描述 输入第一行&#xff0c;包含一个正整数N。约定2<N<10^12 输出描述 输出一行&#xff0c;为N…

Web APIs 6 正则表达式

Web APIs 6 正则表达式1、介绍2、语法方法一方法二 3、元字符分类① 边界符② 量词③ 字符类 案例&#xff1a;用户名验证 4、修饰符案例&#xff1a;过滤敏感字 案例&#xff1a;小兔鲜注册注册模块 正则表达式 1、介绍 正则表达式&#xff08;Regular Expression&#xff0…

OpenAI (ChatGPT)中国免费试用地址

GitHub - click33/chatgpt---mirror-station-summary: 汇总所有 chatgpt 镜像站&#xff0c;免费、付费、多模态、国内外大模型汇总等等 持续更新中…… 个人能力有限&#xff0c;搜集到的不多&#xff0c;求大家多多贡献啊&#xff01;众人拾柴火焰高&#xff01;汇总所有 cha…

uniapp模仿下拉框实现文字联想功能 - uniapp输入联想(官方样式-附源码)

一、效果 废话不多说&#xff0c;上效果图&#xff1a; 在下方的&#xff1a; 在上方的&#xff1a; 二、源码 一般是个输入框&#xff0c;输入关键词&#xff0c;下拉一个搜索列表。 ElementUI有提供<el-autocomplete>&#xff0c;但uniapp官网没提供这么细&#x…

基于Vue的实时影片资讯APP设计与实现

目 录 摘 要 I Abstract II 引 言 1 1 相关技术 3 1.1 Vue框架 3 1.2 MVVM 3 1.3 Mongodb数据库 4 1.4 Axios请求 4 1.5 H5、CSS3和JavaScript 5 1.6 本章小结 5 2 系统分析 7 2.1 功能需求 7 2.2 用例分析 7 2.3 用户功能 8 2.4本章小结 8 3 Vue影片票务服务APP设计 9 3.1 页…

基于华为atlas的unet分割模型探索

Unet模型使用官方基于kaggle Carvana Image Masking Challenge数据集训练的模型。 模型输入为572*572*3&#xff0c;输出为572*572*2。分割目标分别为&#xff0c;0&#xff1a;背景&#xff0c;1&#xff1a;汽车。 Pytorch的pth模型转化onnx模型&#xff1a; import torchf…

【蓝桥杯】单词分析 (BF)

一.题目描述 二.问题分析 //单词分析 #include <iostream> using namespace std;const int N1e42; char s[N]; int c[26]{0};int main(int argc, const char * argv[]) {ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);cin>>s;int max0,i0;char xa;while(s[i]){…

【Python使用】python高级进阶知识md总结第1篇:My Awesome Book【附代码文档】

python高级进阶全知识知识笔记总结完整教程&#xff08;附代码资料&#xff09;主要内容讲述&#xff1a;My Awesome Book&#xff0c;My Awesome Book。My Awesome Book&#xff0c;MySQL数据库。My Awesome Book&#xff0c;聚合函数。My Awesome Book&#xff0c;创建表并给…

Mysql深入学习 基础篇 Ss.06 事务

青青子衿&#xff0c;悠悠我心 纵我不往&#xff0c;子宁不嗣音 —— 24.3.9 事务&#xff1a; 事务简介 事务操作 事务四大特性 并发事务问题 事务隔离级别 一、事务简介 事务是一组操作的集合&#xff0c;它是一个不可分割的工作单位&#xff0c;事务会把所有的操作作为一个整…

开源的Java图片处理库介绍

在 Java 生态系统中&#xff0c;有几个流行的开源库可以用于图片处理。这些库提供了丰富的功能&#xff0c;如图像缩放、裁剪、颜色调整、格式转换等。以下是几个常用的 Java 图片处理库的介绍&#xff0c;包括它们的核心类、主要作用和应用场景&#xff0c;以及一些简单的例子…

MATLAB2020a安装编译器mingw-64(6.3.0)

MATLAB2020a指定安装mingw-64&#xff08;6.3.0&#xff09;版本编译器 记录一下几个要点 mingw-64&#xff08;6.3.0&#xff09; 找到对应的mingw-64安装包 设置mingw的bin文件路径到环境变量 变量名&#xff1a;MW_MINGW64_LOC MATLAB设置路径

java 哨兵线性搜索

顾名思义&#xff0c;哨兵线性搜索是线性搜索的一种&#xff0c;与传统线性搜索相比&#xff0c;比较次数减少了。在传统的线性搜索中&#xff0c;仅进行N次比较&#xff0c;而在哨兵线性搜索中&#xff0c;哨兵值用于避免任何越界比较&#xff0c;但没有专门针对正在搜索的元素…

快速瓦斯封孔器请满载希望出发

不论昨天如何&#xff0c;今天请满载希望出发&#xff01;每一个微笑、每一次服务&#xff0c;都是我们通往成功巅峰的阶梯。 一、 用途&#xff1a; CKF&#xff0d;I型快速瓦斯封孔器用以快速封闭采面卸压抽放钻孔&#xff0c;具有重量轻、速度快、操作简便的特点&#xff1…

Python中的装饰器详解及实际应用【第120篇—装饰器详解】

Python中的装饰器详解及实际应用 在Python编程中&#xff0c;装饰器&#xff08;Decorator&#xff09;是一种强大而灵活的工具&#xff0c;用于修改函数或方法的行为。它们广泛应用于许多Python框架和库&#xff0c;如Flask、Django等。本文将深入探讨装饰器的概念、使用方法…

C/C++实现代码雨效果

C/C实现代码雨效果 目录 C/C实现代码雨效果 说明使用的库说明测试代码效果图 说明 最近整理电脑资料&#xff0c;翻出了以前写的代码&#xff0c;顺便整理一下到博客上&#xff0c;当做一次备份记录 先看看静态效果 需要分为以下步骤实现 生成代码串把代码串绘制到窗口中使…

NUMA架构

UMA架构 在单cpu的时代&#xff0c;cpu与内存的交互需要通过北桥芯片来完成。cpu通过前端总线(FSB&#xff0c; front Side Bus)连接到北桥芯片&#xff0c;由北桥芯片连接到内存&#xff08;内存控制器是集成在北桥芯片里的&#xff09;。为了提升性能&#xff0c;cpu的频率不…