Loading [MathJax]/jax/input/TeX/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >蓝桥杯历届试题 蚂蚁感冒(模拟版+非模拟板)---C语言—菜鸟级

蓝桥杯历届试题 蚂蚁感冒(模拟版+非模拟板)---C语言—菜鸟级

作者头像
Fivecc
发布于 2022-11-21 06:34:21
发布于 2022-11-21 06:34:21
41000
代码可运行
举报
文章被收录于专栏:前端ACE前端ACE
运行总次数:0
代码可运行

/*问题描述   长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。

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

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

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

请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。 输入格式   第一行输入一个整数n (1 < n < 50), 表示蚂蚁的总数。

接着的一行是n个用空格分开的整数 Xi (-100 < Xi < 100), Xi的绝对值, 表示蚂蚁离开杆子左边端点的距离。正值表示头朝右,负值表示头朝左, 数据中不会出现0值,也不会出现两只蚂蚁占用同一位置。其中, 第一个数据代表的蚂蚁感冒了。 输出格式   要求输出1个整数,表示最后感冒蚂蚁的数目。 样例输入 3 5 -2 8 样例输出 1 样例输入 5 -10 8 -20 12 25 样例输出 3 思路;模拟 为了排除 两只蚂蚁相距1米 同向 前面蚂蚁碰头与与同向的蚂蚁碰头在含有0.5的情况 把杆长变为200米 蚂蚁初始位至少2米 速度每半秒1米 防止处理0.5 只处理整数 以半秒位单位 模拟每单位时间每一只蚂蚁 的状态

*/

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include <stdio.h>
int ab(int s)//取绝对值 
{if(s>=0)return s;
   else return -s;
}
int main()
{int i,n,t,sum=1;int a[51];//i 代表蚂蚁序号 a[i] 存第i只蚂蚁当前位置 
int gm[51]={0};gm[1]=1;//标记感冒的蚂蚁序号 感冒 为1 
int ms[201]={0};// i 代表米数 ms[i]存放 当前时间当前米数 若存在蚂蚁占据则存在蚂蚁的序号 不存在为0 
  scanf("%d",&n);
  for(i=1;i<=n;i++)
  {scanf("%d",&a[i]);
     a[i]*=2;//初始位置翻倍  
  } 
  t=n;
  while(1)
  {
  	for(i=1;i<=n;i++)
  	 if(ab(a[i])>0&&ab(a[i])<200)//若当前蚂蚁的位置(绝对值)=0或200 则已离开杆 否则在杆上 
	   {	  a[i]+=1;  //每一时间单位蚂蚁位置变动 
  	    if(ms[ab(a[i])]==0)ms[ab(a[i])]=i;//判断当前米数是否已有其他蚂蚁到达;没有则先占据此米数 
  	    else   // ms[ab(a[i])]=已占据该米数的蚂蚁序号 
		 {  if(gm[ms[ab(a[i])]]+gm[i]==1)//已有蚂蚁占据 必然会碰头 判断碰头两只蚂蚁是否感冒 
			  {gm[ms[ab(a[i])]]=gm[i]=1;sum++;}  //感冒则标记 gm[ms[ab(a[i])]]代表已占据的蚂蚁感冒状态  
		                     // gm[i]代表当前蚂蚁感状
			a[ms[ab(a[i])]]=-a[ms[ab(a[i])]];//碰头 方向向取反
		     a[i]=-a[i]; 
  	     }
  	   }else {t--;}//t记录在杆蚂蚁只数 
  	     if(t<=1)break;//若蚂蚁只有一只在杆上则 跳出 
  	      t=n;
		for(i=1;i<=n;i++)
  if(ms[ab(a[i])]!=0)ms[ab(a[i])]=0;//消除蚂蚁去过的米数的标记;时间进入下0.5秒 
  }
	printf("%d\n",sum);
	return 0;
}**


思路:看看图 有什莫想法 黑色代表 首只感冒蚂蚁 红色代表 会感冒蚂蚁 蓝色代表 不会感冒 蚂蚁向碰头 都转向 可看作 都不转向 看成擦肩而过 图 1 2 为一般情况 3 4 为特殊情况 仔细想想 或画图 看看 (两只蚂蚁相遇各自反向可以看作是两只蚂蚁分别继续前进, 然后假如感冒蚂蚁向左行,则会感染它左边所有向右行的蚂蚁,因为它继续向左行, 别感染的第一只蚂蚁继续向右行,感染所有它右边向左行的蚂蚁。)

*/

(非模拟 0ms 改版)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include<stdio.h>
 int abss(int s)//取绝对值 
 { if(s<0)return -s;
    else return s;
 }
int  main()
{
  int qans=0,hans=0,n,i,gm,s;
  scanf("%d",&n); 
  scanf("%d",&gm);//gm 首个感冒蚂蚁 位值 
  	  for(i=1;i<n;i++)
  	   {
  	     scanf("%d",&s);
  	     if(abss(gm)<abss(s)&&s<0)hans++;//当在首个蚂蚁右侧并且反向 必感冒 
  	     if(abss(gm)>abss(s)&&s>0)qans++;//当在首个蚂蚁左侧并且正向 必感冒 
  	   }
  if(gm>0&&hans!=0||gm<0&&qans!=0)printf("%d",qans+hans+1);
   else printf("1");//当首个感冒蚂蚁方向为正时 在首个蚂蚁右侧并且反向 为 0 或  
return 0; //当首个感冒蚂蚁方向为负时 在首个蚂蚁左侧并且反向 为 0 则不会被感冒除首个感冒 
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-03-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
蓝桥杯 历届试题 蚂蚁感冒
接着的一行是n个用空格分开的整数 Xi (-100 < Xi < 100), Xi的绝对值,表示蚂蚁离开杆子左边端点的距离。正值表示头朝右,负值表示头朝左,数据中不会出现0值,也不会出现两只蚂蚁占用同一位置。其中,第一个数据代表的蚂蚁感冒了。
Yuyy
2022/06/28
2300
蓝桥杯之蚂蚁感冒
标题:蚂蚁感冒 长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。 每只蚂蚁都只能沿着杆子向前爬,速度是1厘米/秒。 当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。 这些蚂蚁中,有1只蚂蚁感冒了。并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。 请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。
Max超
2019/01/21
6800
历届试题 蚂蚁感冒
问题描述   长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。
AI那点小事
2020/04/20
3450
蚂蚁感冒(蓝桥杯)
接着的一行是 n 个用空格分开的整数 Xi, Xi 的绝对值表示蚂蚁离开杆子左边端点的距离。
GeekLiHua
2025/01/21
850
[每日一题]问题 1454[蓝桥杯][历届试题]蚂蚁感冒
每日一题 题目描述 长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。 每只蚂蚁都只能沿着杆子向前爬,速度是1厘米/秒。 当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。 这些蚂蚁中,有1只蚂蚁感冒了。并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。 请你计算,当所有蚂蚁都爬离杆子时,有多少只蚂蚁患上了感冒。 输入 第一行输入一个整数n (1 < n < 50), 表示蚂蚁的总数。 接着的一行是n个用空格分开的整数 Xi (-100 <
编程范 源代码公司
2018/04/18
6470
Python|蚂蚁感冒
长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左,有的朝右。每只蚂蚁都只能沿着杆子向前爬,速度是1厘米/秒。当两只蚂蚁碰面时,它们会同时掉头往相反的方向爬行。这些蚂蚁中,有1只蚂蚁感冒了。并且在和其它蚂蚁碰面时,会把感冒传染给碰到的蚂蚁。
算法与编程之美
2020/07/17
5290
2014年第五届蓝桥杯C/C++B组省赛题目解析
一、啤酒和饮料 啤酒每罐2.3元,饮料每罐1.9元。小明买了若干啤酒和饮料,一共花了82.3元。 我们还知道他买的啤酒比饮料的数量少,请你计算他买了几罐啤酒。 注意:答案是一个整数。请通过浏览器提交答案。 不要书写任何多余的内容(例如:写了饮料的数量,添加说明文字等)。 分析:此题可用循环暴力求解出结果。 数值先都扩大十倍,方便计算。 全部啤酒罐数:823/23=35.78;全部饮料罐数:823/19=43.31;啤酒和饮料对半罐数:823/42=19.59 设啤酒x,饮料y,则根据上述计算可知,x<y,2
Zoctopus
2018/06/04
2.8K0
2014年第五届C/C++ B组蓝桥杯省赛真题
题目描述 啤酒每罐2.3元,饮料每罐1.9元。小明买了若干啤酒和饮料,一共花了82.3元。我们还知道他买的啤酒比饮料的数量少,请你计算他买了几罐啤酒。 题目分析 题目代码
Max超
2020/12/17
6400
2014年第五届C/C++ B组蓝桥杯省赛真题
蓝桥杯 邮票(动态规划)--------------C语言—菜鸟级
/*问题描述   给定一个信封,有N(1≤N≤100)个位置可以贴邮票,每个位置只能贴一张邮票。 我们现在有M(M<=100)种不同邮资的邮票,面值为X1,X2….Xm分(Xi是整数,1≤Xi≤255),每种都有N张。
Fivecc
2022/11/21
3780
html+css+js实现点球球小游戏
简介:这是一款休闲类的小游戏,在这款游戏里面你可以通过鼠标点击屏幕中生成的小球,小球爆炸是有特效的,小球的运行方向和生成位置也是随机的,可以通过修改代码来控制,小球生成的数量。
GeekLiHua
2025/01/21
2730
html+css+js实现点球球小游戏
2014年第四届C/C++ A组蓝桥杯省赛真题
题目描述 小明带两个妹妹参加元宵灯会。别人问她们多大了,她们调皮地说:“我们俩的年龄之积是年龄之和的6倍”。小明又补充说:“她们可不是双胞胎,年龄差肯定也不超过8岁啊。” 请你写出:小明的较小的妹妹的年龄。 题目分析 题目代码
Max超
2020/12/22
6580
2014年第四届C/C++ A组蓝桥杯省赛真题
蓝桥杯历届试题 国王的烦恼(并查集+快排)------C语言—菜鸟级
解题思路:采用并查集的思想,逆向的将树建一遍,所以这里我需要对天数排序, 从大到小进行排序。接着进行建树,在建树的过程中不断地进行判断,我之前是否有 这个桥,如果没有那么就抗议次数++。这里还有一个需要注意的就是:前一次是在 第几天抗议的,如果是同一天的话就不要++了,所以这里要特殊判断一下。
Fivecc
2022/11/21
2940
蓝桥杯 名次判断(详解)----------------C语言—菜鸟级
/*问题描述   某场比赛过后,你想要知道A~E五个人的排名是什么,于是要求他们每个人说了一句话。 (经典的开头……-_-!)得了第1名的人23,说了假话;得了第5名的人不好意思,也说了假话; 为了使求解问题简单,第3名同样说了假话。(奇数名次说假话) 输入格式   共5行,各行依次表示A~E说的话。   每行包含一个形如“A>=3”的名次判断,即一个大写字母+关系运算符+一个数字,不包含空格。   大写字母AE,关系运算<、<=、=、>=、>、!=,数字15。注意:等于是“=”不是“==”! 输出格式   可能有多解,请按照字典序输出排名序列,每个解一行   最后一行输出解的数量 样例输入 A=2 D=5 E>3 A>2 B!=1 样例输出 ACDEB AECBD BADCE BCADE BDACE CEADB CEBDA 7 */
Fivecc
2022/11/21
4180
蓝桥杯 历届试题 发现环(并查集)--------C语言—菜鸟级
小明的实验室有N台电脑,编号1~N。原本这N台电脑之间有N-1条数据链接相连,恰好构成一个树形网络。在树形网络上,任意两台电脑之间有唯一的路径相连。
Fivecc
2022/11/21
3070
蓝桥杯 历届试题 打印十字(图解)----------C语言—菜鸟级
输入 一个正整数 n (n< 30) 表示要求打印图形的层数。 输出 对应包围层数的该标志。 样例输入 3 样例输出
Fivecc
2022/11/21
3410
蓝桥杯   历届试题   打印十字(图解)----------C语言—菜鸟级
蓝桥杯 历届试题 连号区间数-------------C语言—菜鸟级
/*问题描述 小明这些天一直在思考这样一个奇怪而有趣的问题: 在1~N的某个全排列中有多少个连号区间呢?这里所说的连号区间的定义是: 如果区间[L, R] 里的所有元素(即此排列的第L个到第R个元素)递增排序后能得到一个长度为R-L+1的“连续”数列,则称这个区间连号区间。 当N很小的时候,小明可以很快地算出答案,但是当N变大的时候,问题就不是那么简单了,现在小明需要你的帮助。 输入格式 第一行是一个正整数N (1 <= N <= 50000), 表示全排列的规模。 第二行是N个不同的数字Pi(1 <= Pi <= N), 表示这N个数字的某一全排列。 输出格式 输出一个整数,表示不同连号区间的数目。 样例输入1 4 3 2 4 1 样例输出1 7 样例输入2 5 3 4 2 5 1 样例输出2 9 思路: 暴力枚举
Fivecc
2022/11/21
2950
蓝桥杯 历届试题 对局匹配(dp满分通过)---C语言
蓝桥杯 历届试题 对局匹配 问题描述   小明喜欢在一个围棋网站上找别人在线对弈。这个网站上所有注册用户都有一个积分,代表他的围棋水平。 小明发现网站的自动对局系统在匹配对手时,只会将积分差恰好是K的两名用户匹配在一起。 如果两人分差小于或大于K,系统都不会将他们匹配。 现在小明知道这个网站总共有N名用户,以及他们的积分分别是A1, A2, … AN。 小明想了解最多可能有多少名用户同时在线寻找对手,但是系统却一场对局都匹配不起来 (任意两名用户积分差不等于K)? 输入格式   第一行包含两个个整
Fivecc
2022/11/21
6390
蓝桥杯  历届试题 对局匹配(dp满分通过)---C语言
蓝桥杯 历届试题 分考场 (DFS)-----C语言—菜鸟级
有疑问留言 题目测试链接:http://www.dotcpp.com/oj/problem1874.html
Fivecc
2022/11/21
4510
蓝桥杯 算法训练 3000米排名预测---------C语言—菜鸟级
*问题描述   3000米长跑时,围观党们兴高采烈地预测着最后的排名。因为他们来自不同的班,对所有运动员不一定都了解,于是他们分别对自己了解的一些运动员的实力作出了评估,即对部分运动员做了相对排名的预测,并且告诉了可怜留守的班长。因为无聊,于是他们就组团去打Dota去了。比赛结束后他们向班长询问最后的排名,但班长不记得了,只记得他们中哪些人的预测是正确的,哪些人的预测是错误的。他们想知道比赛的排名可能是什么。 输入格式   第一行两个整数n, m,n为运动员数量,m为围观党数量。运动员编号从0到n-1。   接下来m行,每行为一个围观党的相对排名预测。每行第一个数c表示他预测的人数,后面跟着c个0~n-1的不同的数,表示他预测的运动员相对排名,最后还有一个数,0表示这个预测是错误的,1表示是正确的。 输出格式   第一行一个数k为有多少种排名的可能。   下面k行,每行一个0~n-1的排列,为某一个可能的排名,相邻的数间用空格隔开。所有排名按字典序依次输出。 样例输入 Input Sample 1: 3 2 2 0 1 1 2 1 2 0
Fivecc
2022/11/21
3290
蓝桥杯 历届试题 地库取宝(深搜 dfs)----------C语言—菜鸟级
/*问题描述   X 国王有一个地宫宝库。是 n x m 个格子的矩阵。每个格子放一件宝贝。每个宝贝贴着价值标签。
Fivecc
2022/11/21
3410
推荐阅读
相关推荐
蓝桥杯 历届试题 蚂蚁感冒
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验