長100厘公尺的細長直桿子上有n只螞蟻。它們的頭有的朝左,有的朝右。
每只螞蟻都只能沿著桿子向前爬,速度是1厘公尺/秒。
當兩隻螞蟻碰面時,它們會同時掉頭往相反的方向爬行。
這些螞蟻中,有1只螞蟻感冒了。並且在和其它螞蟻碰面時,會把感冒傳染給碰到的螞蟻。
請你計算,當所有螞蟻都爬離桿子時,有多少只螞蟻患上了感冒。
第一行輸入乙個整數n (1 < n < 50), 表示螞蟻的總數。
接著的一行是n個用空格分開的整數 xi (-100 < xi < 100), xi的絕對值,表示螞蟻離開桿子左邊端點的距離。正值表示頭朝右,負值表示頭朝左,資料中不會出現0值,也不會出現兩隻螞蟻占用同一位置。其中,第乙個數 據代表的螞蟻感冒了。
要求輸出1個整數,表示最後感冒螞蟻的數目。
5-10 8 -20 12 25
黑色代表感冒的螞蟻,紅色代表會被感冒的螞蟻,綠色代表不會被感冒的螞蟻
在上面這種情況下:黑色的螞蟻方向向右,它右邊與它方向相反的螞蟻都會被感染(記作cou1),被感染的螞蟻反向(也就相當於乙個向左,乙個向右,可以看成按原方向走),被感染的螞蟻會感染與它方向相反的螞蟻(記作cou2)
則當cou1>0時:
被感染的螞蟻總數為:1+cou1+cou2
當cou1=0時;
被感染的螞蟻總數為:1
cou1=0為下面這種情況,在它的右邊沒有與之方向相反的螞蟻
則當cou1>0時:
被感染的螞蟻總數為:1+cou1+cou2
當cou1=0時;
被感染的螞蟻總數為:1
cou1=0為下面這種情況,在它的左邊沒有與之方向相反的螞蟻
//如果第乙個感冒螞蟻能夠感染螞蟻,則加上被感染的螞蟻和被感染螞蟻可以感染的螞蟻數量
s+=cou1+cou2;
if(a[0]
<
0&&cou1>0)
s+=cou1+cou2;
printf
("%d"
,s);
return0;
}
藍橋杯 歷屆試題 螞蟻感冒
分析 1 因為只計算數量,所以螞蟻是掉頭還是直接向前走對本題沒有影響 2 如果感冒的螞蟻方向向左 在它左邊的螞蟻 如果向右,則會感染 如果向左則不會感染 在它右邊的螞蟻 如果向右,則不會感染 如果向左 1 如果感冒的那只螞蟻左邊有向右的螞蟻,他會掉頭,則右邊向左的螞蟻會感冒 2 如果感冒的那只螞蟻左...
藍橋杯歷屆試題 螞蟻感冒
問題描述 長100厘公尺的細長直桿子上有n只螞蟻。它們的頭有的朝左,有的朝右。每只螞蟻都只能沿著桿子向前爬,速度是1厘公尺 秒。當兩隻螞蟻碰面時,它們會同時掉頭往相反的方向爬行。這些螞蟻中,有1只螞蟻感冒了。並且在和其它螞蟻碰面時,會把感冒傳染給碰到的螞蟻。請你計算,當所有螞蟻都爬離桿子時,有多少只...
藍橋杯 歷屆試題 螞蟻感冒
這道題分析了一下得出的結論就是最後感冒的螞蟻數量等於絕對值比第乙個感冒的螞蟻的位置大的且方向向左,還有就是比第乙個感冒的螞蟻的位置小的且方向向右。這裡我們很明顯可以發現2個螞蟻碰面之後並沒有什麼影響,2個速度相同的螞蟻同時掉頭不如直接看成速度相同的螞蟻繼續向前走 include include in...