给定三条边a\b\c,请你判断一下能不能组成一个三角形

题目:给定三条边a\b\c,请你判断一下能不能组成一个三角形
输入描述:

输入包含多组数据,每组数据包含三个正整数a、b、c(1≤a, b, c≤10^100)

输出描述:

对应每一组数据,如果它们能组成一个三角形,则输出"Yes";否则,输出"No"。

实现思路:

1.因为要输入多组数据,所以将所有代码放在while循环里。

2.因为输入的数字可能是超大整数,所以直接定义BigInteger保存超大整数

3.找出最大值、最小值、中间值 ,由于是引用数据类型,所以用compareTo进行三元运算

4.比较:若Max<(Min+Mid),则可以说明任意两边之和大于第三边

java 复制代码
package com.ztt.Demo01;

import java.math.BigInteger;
import java.util.Scanner;
//给定三条边a\b\c,请你判断一下能不能组成一个三角形
// 1 <= a\b\c <= 10^100

public class demo01 {

	public static void main(String[] args) {
		//定义BigInteger保存超大整数
		Scanner input=new Scanner(System.in);
		BigInteger a=null;
		BigInteger b=null;
		BigInteger c=null;
		
		while(input.hasNext()) {
		 a=input.nextBigInteger();
		 b=input.nextBigInteger();
		 c=input.nextBigInteger();
		 
		 //1.找出max、 min、mid
		 // max
		 // a > b ? (a > c ? a : c) : (b > c ? b : c)
		BigInteger max=(a.compareTo(b)>=0)?(a.compareTo(c)>0 ?a:c):(b.compareTo(c)>0 ?b:c);
		
		// min
		// a < b ? (a < c ? a : c) : (b < c ? b : c)
		BigInteger min=(a.compareTo(b)<=0)?(a.compareTo(c)<0 ?a:c):(b.compareTo(c)<0 ?b:c);
		
		//mid
		//(a+b+c)-max-min
		BigInteger mid=a.add(b).add(c).subtract(max).subtract(min);
		
		//(max<(min+mid))? "YES" : "NO";
		String ret=max.compareTo(min.add(mid))<0 ? "YEA":"NO";
		System.out.println(ret);
		}
	}

}

运行结果:

java 复制代码
1 2 3
NO

5 12 13
YES
相关推荐
苏瞳儿1 小时前
java对数据库的增删改查
java·数据库·oracle
zhangjw341 小时前
Java基础语法:变量、数据类型与运算符,从原理到实战
java·开发语言
算法鑫探5 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
yaoxin5211235 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
java·开发语言·python
WBluuue5 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
NotFound4865 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
木子墨5165 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
Ava的硅谷新视界6 小时前
用了一天 Claude Opus 4.7,聊几点真实感受
开发语言·后端·编程
rabbit_pro6 小时前
Python调用onnx模型
开发语言·python
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌