如何用java实现小明最近迷上了一款名为《扫雷》的游戏。 其中有一个关卡的任务如下: 在一个二维平面上放置着 n 个炸雷,第 i 个炸雷 (xi,yi,ri) 表示在坐标 (xi,yi) 处存在一个炸...

文章介绍了如何使用Java编程实现炸雷和排雷火箭的碰撞检测。通过定义一个Explosion类来存储坐标和半径信息,然后创建一个canExplode函数计算两者之间的距离并判断是否能爆炸。接着,读取输入数据,遍历数组进行碰撞计数,最后输出结果。
摘要由CSDN通过智能技术生成

要用 Java 实现这个任务,可以先定义一个类来表示炸雷和排雷火箭,每个炸雷或排雷火箭由坐标 (x,y) 和半径 r 组成。可以这样定义这个类:

class Explosion {
    int x;
    int y;
    int r;

    public Explosion(int x, int y, int r) {
        this.x = x;
        this.y = y;
        this.r = r;
    }
}

然后可以写一个函数来判断两个炸雷或排雷火箭是否能互相爆炸。可以这样实现:

boolean canExplode(Explosion e1, Explosion e2) {int dx = e1.x - e2.x;
    int dy = e1.y - e2.y;
    double distance = Math.sqrt(dx * dx + dy * dy);
    return distance <= e1.r + e2.r;
}

最后,可以读入输入数据,并使用上述函数来统计答案。代码如下:

``` import java.util.Scanner;

public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); int m = scanner.nextInt(); Explosion[] mines = new Explosion[n]; for (int i = 0; i < n; i++) { int x = scanner.nextInt(); int y = scanner.nextInt(); int r = scanner.nextInt(); mines[i] = new Explosion(x, y, r); } Explosion[] rockets = new Explosion[m]; for (int i = 0; i < m; i++) { int x = scanner.nextInt(); int y = scanner.nextInt(); int r = scanner.nextInt(); rockets[i] = new Explosion(x, y, r); } int count = 0; for (Explosion mine : mines) { for (Explosion rocket : rockets) { if (canExplode(mine, rocket)) { count++; break; } } } System.out.println(count); } }

class Explosion { int x; int y; int r;

publicExplosion(int x, int y, int r) {
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值