L1-067 洛希极限(10分)[java][python]

题目ID :L1-067
分数 :10分
语言:Java / Python

题目描述

科幻电影《流浪地球》中一个重要的情节是地球距离木星太近时,大气开始被木星吸走,而随着不断接近地木"刚体洛希极限",地球面临被彻底撕碎的危险。

洛希极限(Roche limit)是一个天体自身的引力与第二个天体造成的潮汐力相等时的距离。当两个天体的距离少于洛希极限,天体就会倾向碎散,继而成为第二个天体的环。

计算公式

  • 洛希极限 = 密度比值 × 倍数(大天体半径倍数)

倍数

  • 流体:2.455
  • 刚体:1.26

判断条件:如果两个天体的距离 / 大天体半径 >= 洛希极限,则不会被撕碎。

输入格式

输入在一行中给出3个数字,依次为:

  1. 大天体密度与小天体的密度的比值开3次方后计算出的值(≤1)
  2. 小天体的属性(0表示流体、1表示刚体)
  3. 两个天体的距离与大天体半径的比值(>1 但不超过10)

输出格式

在一行中首先输出小天体的洛希极限与大天体半径的比值(输出小数点后2位);随后空一格;最后输出:

  • ^_^ 如果小天体不会被撕碎
  • T_T 如果小天体会被撕碎

输入样例

复制代码
0.622 0 1.4

输出样例

复制代码
1.53 T_T

解题思路

  1. 根据小天体属性(0=流体,1=刚体)选择对应的倍数
  2. 计算洛希极限 = 密度比值 × 倍数
  3. 比较距离与大天体半径的比值与洛希极限:
    • 如果距离比 >= 洛希极限:不会被撕碎,输出 ^_^
    • 如果距离比 < 洛希极限:会被撕碎,输出 T_T

代码实现

Java

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        double density = scanner.nextDouble();  // 密度比值开三次方
        int type = scanner.nextInt();            // 0=流体, 1=刚体
        double dist = scanner.nextDouble();       // 距离与大天体半径的比值

        // 计算洛希极限
        double roche = type == 0 ? density * 2.455 : density * 1.26;

        // 输出结果
        System.out.printf("%.2f ", roche);
        if (dist >= roche) {
            System.out.println("^_^");
        } else {
            System.out.println("T_T");
        }
    }
}

Python

python 复制代码
density, typ, dist = map(float, input().split())
typ = int(typ)

# 计算洛希极限
roche = density * 2.455 if typ == 0 else density * 1.26

# 输出结果
print(f"{roche:.2f}", end=" ")
if dist >= roche:
    print("^_^")
else:
    print("T_T")

运行验证

样例输入 样例输出 结果
0.622 0 1.4 1.53 T_T
0.622 1 1.4 0.78 _

样例1解释:密度比0.622,流体倍数2.455,洛希极限=1.53,距离比1.4 < 1.53,会被撕碎。

样例2解释:密度比0.622,刚体倍数1.26,洛希极限=0.78,距离比1.4 >= 0.78,不会被撕碎。

复杂度分析

  • 时间复杂度:O(1)
  • 空间复杂度:O(1)

总结

本题考察简单的数学计算和条件判断:

  1. 根据属性选择正确的倍数
  2. 计算洛希极限
  3. 比较判断并输出相应表情
相关推荐
jinyishu_1 小时前
链表经典OJ题
c语言·数据结构·算法·链表
java1234_小锋1 小时前
Spring AI 2.0 开发Java Agent智能体 - Spring AI项目调用本地Ollama模型
java·人工智能·spring·spring ai2.0
二哈赛车手1 小时前
新人笔记---多策略搭建策略执行链实现RAG检索后过滤
java·笔记·spring·设计模式·ai·策略模式
PESS ABIN1 小时前
JavaWeb项目打包、部署至Tomcat并启动的全程指南(图文详解)
java·tomcat
l1t1 小时前
DeepSeek总结的DuckDB anofox-forecast季节调整时间序列预测插件功能
开发语言·数据库
葫三生2 小时前
三生原理文章被AtomGit‌开源社区收录的意义探析?
人工智能·深度学习·神经网络·算法·搜索引擎·开源·transformer
xyq20242 小时前
SVG 阴影
开发语言
好奇龙猫2 小时前
[大学院ーpython-base learning3: python and recommendation system ]
开发语言·python
AI进化营-智能译站2 小时前
ROS2 C++开发系列15-模板实现通用算法|宏定义ROS2调试开关|一次编码适配多平台
java·c++·算法·ai