OJ 栓奶牛【C】【Python】【二分算法】

news2024/11/26 8:51:36

题目

算法思路

要求的距离在最近木桩与最远木桩相隔距离到零之间,所以是二分法

先取一个中间值,看按照这个中间值可以栓多少奶牛,再与输入奶牛数比较,如果大于等于,则增大距离,注意这里等于也是增大距离,因为要求的是最大距离,如果这个距离还能再大点呢,如果小于说明距离太大,缩小距离

C代码

//二分法
#include<stdio.h>
int main(){
  int n,k,p1;
  scanf("%d %d %d",&n,&k,&p1);
  int muzhuang[k+1];
  muzhuang[1]=p1;
  int i;
  for(i=2;i<=k;i++){
    muzhuang[i]=muzhuang[i-1]+((muzhuang[i-1]*2357+137)%10)+1;
  }
  int left,right,mid;
  left=0,right=k;
  int sum,t,ans;
  while(left<=right){
    mid=(left+right)/2;
    sum=1;
    t=1;
    for(i=2;i<=k;i++){
      if(muzhuang[i]-muzhuang[t]>=mid){
        t=i;
        sum++;
      }
    }
    //距离太小,如果等于,则要看看还能不能再大一点
    if(sum>=n){
      ans=mid;
      left=mid+1;
    }
    //距离太大
    else{
      right=mid-1;
    }
  }
  printf("%d",ans);
  return 0;
}

Python代码

n, k, p1 = map(int, input().split(' '))
lst = [p1]
for i in range(1, k):
    lst_i = lst[i - 1] + (lst[i - 1] * 2357 + 137) % 10 + 1
    lst.append(lst_i)  # 注意防止下标越界
left, right, ans = 0, k - 1, 0
while left <= right:
    mid = (left + right) // 2  # 注意python不会自动取整
    sum1, t = 1, 0
    for i in range(k):
        if lst[i] - lst[t] >= mid:
            t = i
            sum1 += 1
    if sum1 >= n:
        ans = mid
        left = mid + 1
    else:
        right = mid - 1
print(ans)

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

NC报销单设置了转换模板后,没有生成临时凭证的排查。

NC报销单设置了转换模板后&#xff0c;没有生成临时凭证的排查 1、检查转换模板 2、检查交易类型 3、检查平台设置

RTK大气延迟建模精度分析

大气建模内插精度与终端定位性能密切相关。与流动站最近的参考站称为主参考站&#xff0c;此算例中&#xff0c;LXJS作为HF06的主参考站。图5分别给出了LXJS-HF06基线GPS时&#xff08;GPS time&#xff0c;GPST&#xff09; 00:00—24:00内GPS和BDS可视卫星的双差电离层延迟结…

App加固:不同类型和费用对比

文章目录 [TOC]引言应用程序加固是什么不同类型[App加固](https://www.ipaguard.com/)的费用对比基础加固高级加固云加固 白嫖的混淆加密工具](https://www.ipaguard.com/)-[ipaguard总结参考资料 引言 在当前移动应用市场中&#xff0c;安全性已经成为一个非常重要的话题。为…

2024年厨房大家电行业未来趋势分析(厨电行业线上分析报告)

如今&#xff0c;种种迹象都表明厨电行业正在向高端化、智能化、品质化做根本性的转变。不少厨房大家电的市场规模相较去年都有明显增长&#xff0c;其中也包括线上市场。 鲸参谋数据显示&#xff0c;从今年综合传统电商平台&#xff08;京东天猫淘宝&#xff09;1月至2月的数…

图片超分辨率重构实战——SRGAN

数据与代码链接见文末 论文地址:Photo-Realistic Single Image Super-Resolution Using a Generative Adversarial Network https://arxiv.org/abs/1609.04802v4 1.概述 通常来说,分辨率越低,图像越模糊,分辨率越高,图像越清晰,图像超分辨率重构就是将分辨率低的图像重…

怎么在手机中制作gif动图?用这个网站一键在线做

手机已经是我们日常生活中必不可少的日用品了&#xff0c;很多以前电脑上的软件现在在手机上也能操作了。我们想要在手机上制作一个gif动图还不想下载一些操作复杂的软件的时候&#xff0c;要怎么办呢&#xff1f;很简单&#xff0c;不用着急只要在手机浏览器上搜索专业的Gif制…

刷题之Leetcode54题(超级详细)

54. 螺旋矩阵54. 螺旋矩阵 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/spiral-matrix/submissions/521329682/ 给你一个 m 行 n 列的矩阵 matrix &#xff0c;请按照 顺时针螺旋顺序 &#xff0c;返回矩阵中的所有元素。 示例 1&#xff1a; 输入…

搭建基于Hexo的个人博客

测试命令 hexo clean hexo g hexo s 上传命令 hexo clean hexo g hexo d 一、安装hexo 参考B站CodeSheep视频&#xff1a;手把手教你从0开始搭建自己的个人博客 |无坑版视频教程| hexo_哔哩哔哩_bilibili 安装node.js nodejs.org下载长期支持版 用管理员身份进入powersh…

全排列与全错排列

import java.util.Arrays; import java.util.Scanner; // 1:无需package // 2: 类名必须Main, 不可修改public class Main {public static void main(String[] args) {Scanner scan new Scanner(System.in);//在此输入您的代码...long f10;long f21;long temp0;for (int i 3;…

提升数据安全与性能,掌握Helm一键部署MySQL 8.0主从技巧

在云原生应用开发中&#xff0c;数据库的高可用性和数据一致性是至关重要的。MySQL作为一种常用的关系型数据库&#xff0c;在云原生环境中的部署和管理也变得愈发重要。本教程将介绍如何使用Helm一键部署MySQL 8.0的主从复制架构&#xff0c;以实现数据库的高可用和数据备份。…

官网下载IDE插件并导入IDE

官网下载IDEA插件并导入IDEA 1. 下载插件2. 导入插件 1. 下载插件 地址&#xff1a;https://plugins.jetbrains.com/plugin/21068-codearts-snap/versions 说明&#xff1a;本次演示以IDEA软件为例 操作&#xff1a; 等待下载完成 2. 导入插件 点击File->setting->Pl…

白帽工具箱:初识Metasploit Framework(MSF)渗透测试框架

&#x1f31f;&#x1f30c; 欢迎来到知识与创意的殿堂 — 远见阁小民的世界&#xff01;&#x1f680; &#x1f31f;&#x1f9ed; 在这里&#xff0c;我们一起探索技术的奥秘&#xff0c;一起在知识的海洋中遨游。 &#x1f31f;&#x1f9ed; 在这里&#xff0c;每个错误都…

实验4 DHCP基础配置

实验4 DHCP基础配置 一、 原理描述二、 实验目的三、 实验内容四、 实验配置五、 实验步骤1.基本配置2.配置DHCPServer功能3.配置DHCP Client 一、 原理描述 动态主机配置协议 DHCP是一个局域网的网络协议&#xff0c;使用UDP协议工作&#xff0c;主要有两个用途&#xff1a;用…

昨天,“支付宝崩了”上热搜; 4 月编程语言排行榜:PHP 跌至历史最低点;老乡鸡 “开源” 了;微信 WCDB 迎来重大升级

0、支付宝崩了”上热搜&#xff0c;官方回应&#xff1a;短暂性访问不畅&#xff0c;已经快速恢复 昨日&#xff0c;有许多网友反映支付宝无法使用&#xff0c;用不了蚂蚁能量收集等功能&#xff0c;#支付宝崩了# 话题冲上微博热搜。 支付宝客服人员回应称&#xff0c;确实有系…

HJ102 字符统计(字符串,TreeMap,TreeMap是按照自身的顺序排序,比如数字的话,按照数字升序,ascII等。)

TreeMap是按照自身的顺序排序&#xff0c;比如数字的话&#xff0c;按照数字升序&#xff0c;ascII等。 import java.util.Scanner; import java.util.TreeMap;// 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main {public static void main(String[] arg…

全志V851se开发板TinyVision镜像制作快速启动教程

制作系统启动镜像​ 烧写系统​ 硬件&#xff1a;TinyVision主板 x1硬件&#xff1a;TypeC-SUB x1硬件&#xff1a;TF卡读卡器 x1硬件&#xff1a;8GB以上的 Micro TF卡 x1软件&#xff1a;Tina系统TF卡烧录工具: PhoenixCard-V2.8软件&#xff1a;TinaTF卡最小系统镜像&…

福特长安福特 福克斯 2013款 两厢经典 1.8L MT基本型

http://www.huanqiuauto.com/cars/656021/ 【两厢经典 1.8L MT基本型_福克斯_报价_参数_油耗_图片】 好像还要加92的汽油这个方面就很难受 3.相关的测试和相关的说明信息 沿袭了福特 WRC赛车滴纯正血统&#xff0c;容易驾驭操控。使用福特C3P系统设计的后悬挂系统和强化底盘&…

Day36:LeedCode 435. 无重叠区间 763.划分字母区间 56. 合并区间 蓝桥杯 管道

435. 无重叠区间 给定一个区间的集合 intervals &#xff0c;其中 intervals[i] [starti, endi] 。返回 需要移除区间的最小数量&#xff0c;使剩余区间互不重叠 。 示例 1: 输入: intervals [[1,2],[2,3],[3,4],[1,3]] 输出: 1 解释: 移除 [1,3] 后&#xff0c;剩下的区间…

基于Dell 3930 RACK服务器的RAID1配置

**背景&#xff1a;**项目上使用的Dell 3930 RACK服务器需要配置RAID1冗余备份功能&#xff0c;设置比较简单&#xff0c;此处也做个记录&#xff0c;以免忘记。 步骤&#xff1a; 1、重启服务器&#xff0c;启动过程中按F12&#xff0c;进入设置界面 2、先选中进入BIOS Setup…

maven中两个打包命令的区别:install命令与package命令

package命令&#xff1a;        将项目打包&#xff08;jar/war&#xff09;&#xff0c;将打包结果放到项目下的 target 目录下 install命令&#xff1a;        1. 将项目打包&#xff08;jar/war&#xff09;&#xff0c;将打包结果放到项目下的 target 目录…