博客
关于我
AcWing寒假每日一题——Day31比例简化
阅读量:137 次
发布时间:2019-02-27

本文共 1206 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要将支持人数A和反对人数B的比例A:B化简为A':B',使得A'和B'不超过给定的上限L,并且A'和B'互质。同时,我们需要确保化简后的比例尽可能接近原比例,并且乘积A'B'尽可能接近A*B。

方法思路

  • 问题分析:我们需要找到一个比例A':B',使得它与原比例A:B尽可能接近,同时满足A'和B'不超过给定的上限L,并且互质。
  • 双重循环遍历:我们遍历所有可能的A'和B'的值,范围都是从1到L。
  • 互质检查:对于每对(A', B'),检查它们是否互质(最大公约数为1)。
  • 比例差异计算:计算每对(A', B')的比例与原比例的差异,记录最小的差异对应的A'和B'。
  • 优化选择:在差异相同的情况下,选择比例更大的A':B'。
  • 解决代码

    #include 
    using namespace std;int a, b, l, best_a, best_b;double ratio = (double)a / b;double min_diff = 1e9;for (int i = 1; i <= l; ++i) { for (int j = 1; j <= l; ++j) { if (gcd(i, j) != 1) continue; double current_ratio = static_cast
    (i) / j; double diff = abs(current_ratio - ratio); if (diff < min_diff) { min_diff = diff; best_a = i; best_b = j; } else if (diff == min_diff) { if (static_cast
    (i) / j > ratio) { best_a = i; best_b = j; } } }}cout << best_a << " " << best_b;

    代码解释

  • 输入处理:读取输入的支持人数A、反对人数B和上限L。
  • 比例计算:计算原比例ratio = A/B。
  • 双重循环遍历:遍历所有可能的A'和B',范围从1到L。
  • 互质检查:使用gcd函数检查当前A'和B'是否互质。
  • 比例差异计算:计算当前比例与原比例的差异,记录最小的差异对应的A'和B'。
  • 优化选择:在差异相同的情况下,选择比例更大的A':B'。
  • 输出结果:打印最优化的A'和B'。
  • 这种方法确保了我们找到一个尽可能接近原比例且满足条件的化简比例。

    转载地址:http://lisb.baihongyu.com/

    你可能感兴趣的文章
    NSGA-Ⅲ源代码
    查看>>
    nsis 安装脚本示例(转)
    查看>>
    NSJSON的用法(oc系统自带的解析方法)
    查看>>
    nslookup 的基本知识与命令详解
    查看>>
    NSNumber与NSInteger的区别 -bei
    查看>>
    NSOperation基本操作
    查看>>
    NSRange 范围
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NSURLSession下载和断点续传
    查看>>
    NSUserdefault读书笔记
    查看>>
    NS图绘制工具推荐
    查看>>
    NT AUTHORITY\NETWORK SERVICE 权限问题
    查看>>
    NT symbols are incorrect, please fix symbols
    查看>>
    ntelliJ IDEA 报错:找不到包或者找不到符号
    查看>>
    NTFS文件权限管理实战
    查看>>
    ntko web firefox跨浏览器插件_深度比较:2019年6个最好的跨浏览器测试工具
    查看>>
    ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
    查看>>
    ntp server 用法小结
    查看>>
    ntpdate 通过外网同步时间
    查看>>
    ntpdate同步配置文件调整详解
    查看>>