2023年四川大学生程序设计竞赛-K.倒转乾坤

Cuber QQ 现在手上有两个圆环,其中小圆环的直径是 d,大圆环的直径是 2d

。他将小圆环放在大圆环内, 并让小圆环紧贴大圆环内壁进行无滑动的滚动。

Cuber QQ 总是喜欢动态的美,他在小圆环上等间隔地标记了 n 个点,他想知道在小圆环贴着大圆环运动一周后,他所标记的 n个点所经过的轨迹的长度之和是多少。

输入描述

输入包含一行,两个整数

输出描述

输出包含一行一个浮点数,表示 n 个点所经过的轨迹的长度之和,所输出的答案和标准答案的绝对误差或相对误差在 范围内会被认为是正确的。

样例

输入:

1 1

输出:

4.00000000

思路

这个题首先我们就是要搞清楚小圆上的点的路径是什么?

根据样例我们可以推算一下,把A点取一个特殊的点,假设A点就是紧贴的那个点,转半圈,转一圈,转两圈的位置,大概可以推算出他的轨迹就是沿着直径运动

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
    int n,d;
    cin >> n >> d;
    printf("%.7lf",4.0*n*d);
} 
相关推荐
码农多耕地呗12 分钟前
力扣543.二叉树的直径(java)(迭代法 and 左右根后序遍历迭代法)
算法·leetcode·职场和发展
努力学习的小廉1 小时前
我爱学算法之—— 分治-归并
c++·算法·1024程序员节
Gorgous—l1 小时前
数据结构算法学习:LeetCode热题100-链表篇(下)(随机链表的复制、排序链表、合并 K 个升序链表、LRU 缓存)
数据结构·学习·算法
仰泳的熊猫1 小时前
LeetCode:200. 岛屿数量
数据结构·c++·算法·leetcode
流星5211221 小时前
GC 如何判断对象该回收?从可达性分析到回收时机的关键逻辑
java·jvm·笔记·学习·算法
sulikey1 小时前
Qt 入门简洁笔记:从框架概念到开发环境搭建
开发语言·前端·c++·qt·前端框架·visual studio·qt框架
傻童:CPU1 小时前
C语言需要掌握的基础知识点之链表
c语言·1024程序员节
defaulter1 小时前
Codeforces Round 1049 (Div. 2)C. Ultimate Value
算法·codeforces
zzzsde1 小时前
【C++】stack和queue:优先级队列的使用及底层原理
开发语言·c++
让我们一起加油好吗2 小时前
【数论】费马小定理
c++·算法·数论·1024程序员节·费马小定理·逆元