IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C案例:最小覆盖圆问题 -> 正文阅读

[C++知识库]C案例:最小覆盖圆问题

一、提出任务 - 最小覆盖圆

(一)描述

  • 给出平面上 N ( N ≤ 1 0 2 ) N(N\le10^2) N(N102)个点。请求出一个半径最小的圆覆盖住所有的点。

(二)输入

  • 第一行给出数字 N N N,接下来 N N N行,每行两个实数 x , y x,y x,y表示其坐标。其中, ? 1 0 5 ≤ x , y ≤ 1 0 5 -10^5\le x,y \le 10^5 ?105x,y105

(三)输出

  • 第一行输出最小覆盖医的圆心
  • 第二行输出半径
  • 输出保留三位小数

(四)样例

输入

4
1 0
0 1
0 -1
-1 0

输出

0.000 0.000
1.000

二、完成任务

(一)编程思路

  • 任意两点间距离的最大值就是最小覆盖圆的直径
  • 距离最大值的两个点的中心就是最小覆盖圆的圆心

(二)编写代码,实现功能

  • C_WORK目录里创建C程序 - 最小覆盖圆.c
    在这里插入图片描述
#include "stdio.h"
#include "math.h"

int main()
{
    int n;
    double distance, maxDistance = 0;
    double cx = 0, cy = 0, r;

    // 输入点数量
    scanf("%d", &n);

    // 声明点坐标数组
    double x[n], y[n];

    // 输入全部点的坐标
    for (int i = 0; i < n; i++)
    {
        scanf("%lf %lf", &x[i], &y[i]);
    }

    // 求两点间最大距离
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            distance = sqrt(pow(x[i] - x[j], 2) + pow(y[i] - y[j], 2));
            if (maxDistance < distance)
            {
                maxDistance = distance;
            }
        }
    }

    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            distance = sqrt(pow(x[i] - x[j], 2) + pow(y[i] - y[j], 2));
            if (maxDistance == distance)
            {
                cx = (x[i] + x[j]) / 2; // 最小覆盖圆圆心横坐标
                cy = (y[i] + y[j]) / 2; // 最小覆盖圆圆心纵坐标
                break;
            }
        }
    }

    // 最小覆盖圆半径
    r = maxDistance / 2;
    4
        // 输出最小覆盖圆圆心坐标
        printf("%.3f %.3f\n", cx, cy);
    // 输出最小覆盖圆半径
    printf("%.3f\n", r);

    return 0;
}

(三)运行程序,查看结果

  • 输入4,与四个点坐标
    在这里插入图片描述
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-12-25 10:47:31  更:2022-12-25 10:50:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/28 5:07:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码