[蓝桥杯] 蚂蚁感冒

[蓝桥杯] 蚂蚁感冒

峰值内存消耗 < 256M  CPU消耗  < 1000ms

【题目描述 - Problem Description】

    长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。

    每只蚂蚁都只能沿着杆子向前爬,速度是1厘米/秒。

    当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。

    这些蚂蚁中,有1只蚂蚁感冒了。并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。

    请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。

【输入 - Input】

【输出 - Output】

  第一行输入一个整数n (1 < n < 50), 表示蚂蚁的总数。

    接着的一行是n个用空格分开的整数 Xi (-100 < Xi < 100), Xi的绝对值,表示蚂蚁离开杆子左边端点的距离。正值表示头朝右,负值表示头朝左,数据中不会出现0值,也不会出现两只蚂蚁占用同一位置。其中,第一个数据代表的蚂蚁感冒了。

    要求输出1个整数,表示最后感冒蚂蚁的数目。

 

【输入样例 1 - Sample Input 1】

【输出样例 1 - Sample Output 1】

3
5 -2 8
1

【输入样例 2 - Sample Input 2】

【输出样例 2 - Sample Output 2】

5
-10 8 -20 12 25
3

 【题解】

模拟,画个图出来大概就清楚了,约等于计数排序。

例如

5

-10 8 -20 12 25

朝左的统计比10小的,朝右的统计比10大的,然后个数相加就是染病蚂蚁的答案。

其他情况就以此类推,上面8与10配对,如果没有配对,直接输出1。

【代码 C++】

 1 #include <cstdio>
 2 int main(){
 3     int R, L, Ri, Li, n, a, i;
 4     scanf("%d%d", &n, &a);
 5     if (a > 0) R = a, Ri = 1, Li = 0;
 6     else L = a, Li = 1, Ri = 0;
 7     if (Ri){
 8         for (i = 1; i < n; ++i){
 9             scanf("%d", &a);
10             if (a>0 && a < R) ++Ri;
11             else if (a < 0 && a + R < 0) ++Li;
12         }
13         if (Li) printf("%d", Ri + Li);
14         else puts("1");
15     }
16     else{
17         for (i = 1; i < n; ++i){
18             scanf("%d", &a);
19             if (a>0 && a + L < 0) ++Ri;
20             else if (a < L) ++Li;
21         }
22         if (Ri) printf("%d", Ri + Li);
23         else puts("1");
24     }
25     return 0;
26 }

【可测评地址】http://acmore.cc/problem.php?id=1614

转载于:https://www.cnblogs.com/Simon-X/p/5304467.html

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

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

相关文章

Source Insight之Relation Window Properties配置和一些快捷键

1 Source Insight之Relation Window Properties配置 我们先点击source Insight的这个地方 然后鼠标右键&#xff0c;点击Relation Window Properties&#xff0c;配置如下 2 快捷键 目前就我知道的 1&#xff09;按亮和按熄这个变量 shift F8 2&#xff09;跳转到具体一行…

ArcGIS 10.2 Calculate Value(Data Management) 工具的使用

1、概述 Calculate Value tool returns a value based on a specified Python expression. 计算值工具返回一个基于特定Python表达式的值。 工具位置:ToolBox→Data Management Tools→General→Calculate Value 2、注意事项 (1)该工具只能用于MoudleBuilder,而不能用于Py…

vb6编写dll读取dat文件_【STM32Cube_15】使用硬件I2C读取温湿度传感器数据(SHT30)...

寻求更好的阅读体验&#xff0c;请移步Mculover666的个人博客&#xff1a;【STM32Cube_15】使用硬件I2C读取温湿度传感器数据&#xff08;SHT30&#xff09;​www.mculover666.cn本篇详细的记录了如何使用STM32CubeMX配置STM32L431RCT6的硬件I2C外设&#xff0c;读取SHT30温湿度…

tcp/ip ---数据封装过程

转载于:https://www.cnblogs.com/saryli/p/5306721.html

NuGet 新特性 -- 中心化的 NuGet 包版本管理

NuGet 新特性 -- 中心化的 NuGet 包版本管理IntroNuGet 支持了一个可以中心化管理 NuGet 包版本的方案&#xff0c;我们可以在一个地方统一管理 NuGet 包的版本Preface在之前的版本中我们通常在每个指定包版本引用的地方会设置 NuGet 包的版本号&#xff0c;如果项目比较多&…

Java面向对象编程学习

1、新建一个工程&#xff0c;在工程下新建一个类Method01&#xff08;勾选创建main函数&#xff09; package ClassStudy;class Person {String name; //默认为nullint age; //默认为0//构造函数public Person(){namenull;age0;}//方法public void say(){System.out.println(&…

查询工资最低的3名员工的职工工号、姓名和收入_普法课堂|你有多久没有收到工资条了?...

工资条对于现在的大多数劳动者而言&#xff0c;尤其是90、00后&#xff0c;可能是一个十分陌生的概念和事物&#xff0c;许多用人单位已经不再向劳动者发放&#xff0c;在司法实践中工资条越来越少的在庭审中予以呈现。工资条对于劳动者而言十分重要&#xff0c;即便未有用人单…

linux之通过tail命令动态跟踪日志文件里面的末尾信息

1 问题场景 比如在linux系统,我们服务端的错误日志在一个文件里面不断输入进去,我们需要动态查看,我们总不可能每次进行cat文件查看 2 tail命令和head命令 head命令默认是输出一个文件的最前面10行 tail命令默认是输出一个文件的最后面10行 1) -n参数 具体显示多少行 显示…

android数据持久化存储(2)

SharedPreferences 将数据存储到SharedPreferences中&#xff1a; 不同于文件的存储方式&#xff0c;SharedPreferences是使用键值对的方式来存储数据的。也就是说当保存一条数据的时候&#xff0c;需要给这条数据提供一个对应的健&#xff0c;这样再读取数据的时候就可以通过这…

清净布气门功夫介绍

如下图片摘自《[中国清净布气门正宗绝技].徐星俊》一书。窥一斑而知全貌&#xff0c;由此可见传统武术有多博大精深&#xff0c;简直是精深已极&#xff01;null转载于:https://www.cnblogs.com/mengshuai1982/p/7344087.html

URL里面携带了#是什么意思

1 问题 有一个链接里面包含了#&#xff0c;格式是这样的 https://域名/#*** 然后进行访问的时候&#xff0c;用Fiddler抓包链接分析&#xff0c;发现链接只有下面的了 https://域名/ 觉得很奇怪&#xff0c;为什么#后面的参数啥的都没有了呢&#xff1f;还以为这里有问题&…

斜率优化(CDQ分治,Splay平衡树):BZOJ 1492: [NOI2007]货币兑换Cash

Description Input 第一行两个正整数N、S&#xff0c;分别表示小Y 能预知的天数以及初始时拥有的钱数。 接下来N 行&#xff0c;第K 行三个实数AK、BK、RateK&#xff0c;意义如题目中所述Output 只有一个实数MaxProfit&#xff0c;表示第N 天的操作结束时能够获得的最大的金钱…

ArcGIS 10.2晕渲图+旋转图制作

晕渲图-通过模拟实际地面本影与落影的方法反映实际地形起伏特征的一种重要的地形图。晕渲图是DEM地表形态表达的一种形式,它通过设置光源的高度角和方位角更形象或者更符合人类视觉的方式展示一个地区的地形。通过晕渲图,可以很好的反应地形地势的变化,有很好的立体感,方便…

unity5.x C# 获取屏幕宽度 设置不受重力影响

在unity5.x中&#xff0c;获取屏幕宽度代码如下&#xff1a; float screenWeight Screen.width; //获取屏幕宽度 Screen.width 在此获取屏幕的宽度&#xff0c;从而赋值给screenWeight变量。 在unity5.x中在inspector中可以设置是否当前游戏对象是否受重力影响&…

sort命令详解及Nginx统计运用

sort命令是帮我们依据不同的数据类型进行排序&#xff0c;其语法及常用参数格式&#xff1a;  sort [-bcfMnrtk][源文件][-o 输出文件] 补充说明&#xff1a;sort可针对文本文件的内容&#xff0c;以行为单位来排序。参  数&#xff1a; -b 忽略每行前面开始出的空格字符…

php扩展开发1--添加函数

目标&#xff1a;便携php扩展 要求实现 输出hello word 首先用的是php7.0.3 centos7.1或者centos6. 1.1 RPM安装PHP rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpmyum install php70wphp -v 看一下 7.0.3php -m 看一下 php70w-devel, php70w-opcache模…

.NET5停止支持,难道就是没前途?

一篇微软官博引发热议&#xff0c;《2022年5月8号.NET5.0将正式停止支持》&#xff0c;此事在.NET5发布时就已经定下来的&#xff0c;文章不过是重申了一下事实&#xff0c;结果却成为某些人眼中的 ”瞎折腾“ ”不靠谱“ ”没前途“&#xff0c;真是无语。技术的更新迭代才是生…

lintcode 418整数转罗马数字

描述 给定一个整数&#xff0c;将其转换成罗马数字。 返回的结果要求在1-3999的范围内。 说明 https://en.wikipedia.org/wiki/Roman_numeralshttps://zh.wikipedia.org/wiki/%E7%BD%97%E9%A9%AC%E6%95%B0%E5%AD%97http://baike.baidu.com/view/42061.htm样例 思路 while循环拆…

linux进程上下文切换,Linux 性能分析总结之 CPU 上下文切换(二)

0x00 前言上一篇笔记中我讲到了&#xff0c;在寻找 CPU 的性能瓶颈的问题的时候&#xff0c;首先会查看整台机器的平均负载是否高&#xff0c;然后再使用 pidstat 等工具判断到底是哪种情况导致的平均负载升高&#xff0c;主要情况有三种&#xff1a;CPU 密集型IO 密集型大量进…

​ArduinoYun教程之ArduinoYun硬件介绍

2019独角兽企业重金招聘Python工程师标准>>> ArduinoYun教程之ArduinoYun硬件介绍 ArduinoYun的电源插座 Arduino Yun有两排插座&#xff0c;这些插座可以按类型分为三类&#xff1a;电源、数字IO和模拟输入。电源部分主要集中在如图1.7所示的部分。 图1.7 电源集中…