14——3

先看一下什么叫转换率的最小值和最大值,看其样例

投入75个o,产出3个x

53个o,换2个x

59个o,换2个x

得出最少20个o换一个x;最多25个o换一个x

也就是说用不同的投入值除以一个相同的数字得到其对应的产出值

而这个相同的数字有多个,在这里面找到头和尾,最大值和最小值。

在实在不会的情况下,可以将投入值和产出值分别输入上下取整的式子中

这里我们用到的方法是二分查找法

二分查找法不一定是要去找,它是有单调性的

我们已经知道它会有2个答案解的,min和max。边界为min>=1;max<=A<=10^9

Bi就是min到max这一整段数据

在这半段对Ai的要求增加时,在o总数不变的情况下,产出x是变少降低的。

也就是转换率V降低了,此时V<Bi

同理,当对Ai的要求减少时,可以取个极端的例子,1个o就可以置换出1个x,那Bi就很大了,那V就是100%了

此时V>Bi

则max在这段找

min在这儿找

二分查找法不一定是要去找,它是有单调性的,只要这半边符合它的性质

而这道题可以分成2个二分查找

这里的V是我们假定出来的答案,我们要做的就是试一试这个V符不符合题目要求


#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include<math.h>//+ —*/都要用
const int MAX_N = 1e4 + 1;//数据最大值范围
int N, A[MAX_N], B[MAX_N];//要输入的数据
bool check_min(int v)
{
    for (int i = 1; i <= N; i++)
    {
        if ((A[i] / v) > B[i])//蓝线之外的max
            return false;
    }
    return true;
}
bool check_max(int v)
{
    for (int i = 1; i <= N; i++)
    {
        if ((A[i] / v) < B[i])//红线之外的min,多重运算带()
            return false;
    }
    return true;
}

int main()
{
    // 请在此输入您的代码
    scanf("%d", &N);
    for (int i = 1; i <= N; i++)
    {
        scanf("%d%d", &A[i], &B[i]);
    }
    int l = 1, R = 1000000000, V_min;//先找最小值,范围1~R
    while (l <= R)
    {
        int mid = (l + R) / 2;//==(l+R)>>1
        if (check_min(mid))//找最小值,则让右边端点往左边缩小移
        {
            V_min = mid;//符合要求,在min和max之间的
            R = mid - 1;//末尾左移
        }
        else
            l = mid + 1;//首位右移
       
        l = 1, R = 1000000000;
        int V_max;//再找最大值,范围1~R	int V_max;要单独写
        while (l <= R)
        {
            int mid = (l + R) / 2;//折半找中间
            if (check_max(mid))//找最大值,则让左边端点往右边缩小移
            {
                V_max = mid;
                l = mid + 1;//左首右移
            }
            else
                R = mid - 1;//右末左移
        }
        printf("%d%d", V_min, V_max);
    }
    //printf("%d%d", V_min, V_max);//记得V_max的作用区域,即看{   }
    return 0;
}

可以看到这个代码块——求最小值的地方出错了;且没有空格间隔

这里最小值直接输出这个了(有可能是花括号的问题)

现在对了

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include<math.h>//+ —*/都要用
const int MAX_N = 1e4 + 1;//数据最大值范围
int N, A[MAX_N], B[MAX_N];//要输入的数据
bool check_min(int v)
{
    for (int i = 1; i <= N; i++)
    {
        if ((A[i] / v) > B[i])//蓝线之外的max
            return false;
    }
    return true;
}
bool check_max(int v)
{
    for (int i = 1; i <= N; i++)
    {
        if ((A[i] / v) < B[i])//红线之外的min,多重运算带()
            return false;
    }
    return true;
}

int main()
{
    // 请在此输入您的代码
    scanf("%d", &N);
    for (int i = 1; i <= N; i++)
    {
        scanf("%d%d", &A[i], &B[i]);
    }
    int l = 1, R = 1000000000, V_min;//先找最小值,范围1~R

    //2个while循环分开
    while (l <= R)
    {
        int mid = (l + R) / 2;//==(l+R)>>1
        if (check_min(mid))//找最小值,则让右边端点往左边缩小移
        {
            // int mid = (l + R) / 2;//==(l+R)>>1
            V_min = mid;//符合要求,在min和max之间的
            R = mid - 1;//末尾左移
        }
        else
            l = mid + 1;//首位右移
    }
       
        l = 1, R = 1000000000;
        int V_max;//再找最大值,范围1~R	int V_max;要单独写
        while (l <= R)
        {
            int mid = (l + R) / 2;//折半找中间
            if (check_max(mid))//找最大值,则让左边端点往右边缩小移
            {
                V_max = mid;
                l = mid + 1;//左首右移
            }
            else
                R = mid - 1;//右末左移
        }
        printf("%d %d", V_min, V_max);
    
    //printf("%d%d", V_min, V_max);//记得V_max的作用区域,即看{   }
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/332527.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【开源】基于JAVA语言的陕西非物质文化遗产网站

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 设计目标2.2 研究内容2.3 研究方法与过程2.3.1 系统设计2.3.2 查阅文献2.3.3 网站分析2.3.4 网站设计2.3.5 网站实现2.3.6 系统测试与效果分析 三、系统展示四、核心代码4.1 查询民间文学4.2 查询传统音乐4.3 增改传统舞…

阿里云ECS使用docker搭建mysql服务

目录 1.确保正确安装好docker 2.安装mysql镜像 3.创建容器&#xff08;设置端口映射、目录映射&#xff09; 1.确保正确安装好docker 安装教程&#xff1a; 阿里云ECS(CentOS镜像)安装docker-CSDN博客https://blog.csdn.net/qq_62262918/article/details/135686614?spm10…

小白数学建模 Mathtype 7.7傻瓜式下载安装嵌入Word/WPS以及深度使用教程

数学建模Mathtype的下载安装嵌入Word/WPS以及深度使用教程 一 Mathtype 的下载安装1.1 安装前须知1.2 下载压缩包1.3 安装注册 二 嵌入Word/WPS2.1 嵌入Word2.1.1 加载项嵌入 Word2.1.2 宏录制嵌入 Word 2.2 嵌入 WPS2.2.1 加载项嵌入 WPS2.2.2 宏录制嵌入 WPS 2.3 嵌入时报错解…

android 开发 W/TextToSpeech: speak failed: not bound to TTS engine

问题 笔者使用TTS(TextToSpeech)对于文本内容进行语音播报&#xff0c;控制台报错 android 开发 speak failed:not bound to TTS engine详细问题 笔者核心代码&#xff1a; import android.os.Bundle; import android.speech.tts.TextToSpeech; import android.speech.tts.…

GB/T28181-2022之图像抓拍规范解读和设计实现

技术背景 GB/T28181-2022相对2016版&#xff0c;对图像抓拍有了明确的界定&#xff0c;图像抓拍在视频监控行业非常重要, Android平台GB28181设备接入端&#xff0c;无需实时上传音视频实时数据的情况下&#xff0c;就可以抓图上传到指定的图像存储服务器上。 图像抓拍基本要…

Gin 框架之用户密码加密

文章目录 一、引入二、密码加密位置三、如何加密四、bcrypt 库加密4.1 介绍4.2 优点&#xff1a;4.3 使用 五、小黄书密码加密实践 一、引入 Gin是一个用Go语言编写的Web框架&#xff0c;而用户密码的加密通常是在应用程序中处理用户身份验证时的一个重要问题。 通常敏感信息…

军事智能中的深度强化学习不同于传统的深度强化学习

在军事智能中&#xff0c;“诡”和“诈”是两个最重要的概念。 “诡”变指的是智能体通过采取一些不可预测或复杂的变化策略来获得优势。诡变可能包括逃避对手的观察或引诱对手采取不利的行动。智能体可以使用诡变来欺骗对手&#xff0c;使其做出错误的决策或暴露其策略。 “诈…

单表查询练习

目录 题目&#xff1a; 制定约束&#xff1a; 添加表格信息&#xff1a; 所需查询的信息&#xff1a; 实验步骤&#xff1a; 第一步&#xff1a;制作表格 创建新的数据库 创建表格约束&#xff1a; 为表格加入数据&#xff1a; 第二步&#xff1a;查询信息 题目&…

C#,入门教程(21)——命名空间(namespace)与程序结构的基础知识

上一篇&#xff1a; C#&#xff0c;入门教程(20)——列表&#xff08;List&#xff09;的基础知识https://blog.csdn.net/beijinghorn/article/details/124094382 编写软件&#xff08;大软件称为系统&#xff09;与盖大楼一个道理。 假设咱们现在需要盖一座名为“天梯大厦”的…

STM32-调用 vTaskStartScheduler API 后出现 HardFault

STM32 移植 FreeRTOS 后调用 vTaskStartScheduler() 后出现 HardFault 异常。 原因分析&#xff1a; FreeRTOS 配置头文件 FreeRTOSConfig.h 中与中断有关的配置和通过系统接口 void NVIC_PriorityGroupConfig(uint32_t NVIC_PriorityGroup) 设置的中断分组冲突。 /* The lo…

含并行连结的网络(GoogLeNet)

目录 1.GoogLeNet 2.代码 1.GoogLeNet inception不改变高宽&#xff0c;只改变通道数。GoogLeNet也大量使用1*1卷积&#xff0c;把它当作全连接用。 V3耗内存比较多&#xff0c;计算比较慢&#xff0c;但是精度比较准确。 2.代码 import torch from torch import nn from t…

Nacos 极简入门

1. 概述 Nacos 是什么&#xff1f;其官方文档自我介绍如下&#xff1a; FROM 什么是 Nacos Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集&#xff0c;帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。 Nacos 帮助您更敏捷和容易…

网易云音乐 API

网易云音乐 API 网易云音乐 API灵感来自环境要求安装运行Vercel 部署操作方法 可以在Node.js调用支持 TypeScript使用文档功能特性更新日志单元测试SDK贡献者License 网易云音乐 API 网易云音乐 Node.js API service 灵感来自 disoul/electron-cloud-music darknessomi/musi…

DDoS攻击规模最大的一次

有史以来DDoS攻击规模最大的是哪一次&#xff1f; Google Cloud团队在2017年9月披露了一次此前未公开的DDoS攻击&#xff0c;其流量达 2.54Tbps&#xff0c;是迄今为止有记录以来最大的DDoS攻击。 在同时发布的另一份报告中&#xff0c;分析高端威胁团体的谷歌安全团队谷歌威胁…

[笔记]深度学习入门 基于Python的理论与实现(四)

4. 神经网络的学习 这里说的‘学习’就是指从训练数据中自动获取最优权重参数的过程。为了进行学习&#xff0c;将导入损失函数这一指标。而学习的目的就是以该损失函数为基准&#xff0c;找出能使它的值达到最小的权重参数。为此&#xff0c;我们介绍利用了函数斜率的梯度法。…

RK3568 android11 移植 v4l2loopback 虚拟摄像头

一&#xff0c;v4l2loopback 简介 v4l2loopback是一个Linux内核模块&#xff0c;它允许用户创建虚拟视频设备。这种虚拟视频设备可以用于各种用途&#xff0c;例如将实际摄像头的视频流复制到虚拟设备上&#xff0c;或者用于视频流的处理和分析等。v4l2loopback的主要作用是创…

大语言模型漏洞缓解指南

虽然大语言模型(LLM)应用正在全球快速普及&#xff0c;但企业对大语言模型的威胁态势仍然缺乏全面了解。面对大语言模型风险的不确定性&#xff0c;企业希望在保障其安全性的基础上加快应用脚步&#xff0c;用人工智能提升企业核心竞争力&#xff0c;这意味着企业的CISO面临着理…

Vray渲染效果图材质参数设置

渲染是创造出引人入胜视觉效果的关键步骤&#xff0c;在视觉艺术领域尤为重要。不过&#xff0c;渲染作为一个资源密集型的过程&#xff0c;每当面对它时&#xff0c;我们往往都会遭遇到时间消耗和资源利用的巨大挑战。幸运的是&#xff0c;有几种方法能够帮助我们优化渲染&…

vue列表飞入效果

效果 实现代码 <template><div><button click"add">添加</button><TransitionGroup name"list" tag"ul"><div class"list-item" v-for"item in items" :key"item.id">{{ i…

恒创科技:云存储和网盘怎么区分出来?

随着互联网的发展&#xff0c;数据存储已成为人们日常生活中不可或缺的一部分。云存储和网盘是经常被人们提及的两种存储方式&#xff0c;均通过网络进行数据存储和访问的服务。但&#xff0c;它们在技术实现、数据安全性、访问方式和数据容量等方面存在一定的差异。要区分&…