原题链接:蓝桥杯历届试题-蚂蚁感冒
解题思路:
注意事项:
参考代码:
#include <iostream>
#include <vector>
#include <stdio.h>
using namespace std;
vector< pair<bool, bool> > ants; // loc, dir
int main()
{
int n = 0, infector = 0;
cin >> n;
for (int i = 0; i < n; i++)
{
int temp = 0;
cin >> temp;
if (i == 0)
infector = temp;
else
{
bool loc, dir;
dir = temp * infector > 0 ? true : false;
if (dir)
loc = temp - infector > 0 ? true : false;
else
loc = temp + infector < 0 ? true : false;
ants.push_back(make_pair(loc, dir));
}
}
int ans = 0;
bool susp = false;
for (int i = 0; i < ants.size(); i++)
{
if (ants.at(i).first == true && ants.at(i).second == false)
{
ans += 1;
susp = true;
}
}
for (int i = 0; i < ants.size(); i++)
if (ants.at(i).first == false && ants.at(i).second == true && susp)
ans += 1;
ans += 1; // Add infector
cout << ans << endl;
return 0;
}
【思路二】
#include <iostream>
#include <algorithm>
#include <math.h>
using namespace std;
int a[60];
int n;
int cnt;
bool cmp(int a, int b){
return abs(a) < abs(b);
}
int main(void){
cin >> n;
int first = 0;
bool flag = false;
for(int i = 0; i < n; i++){
cin >> a[i];
if(i == 0) first = a[i];
}
sort(a, a + n, cmp);
// for(int i = 0; i < n; i++){
// cout << a[i] << " ";
// }
// cout << endl;
if(first > 0){
for(int i = 0; i < n; i++){
if(abs(a[i]) > first && a[i] < 0){
cnt++;
flag = true;
}
}
for(int i = 0; abs(a[i]) < first ; i++){
if(flag && a[i] > 0)
cnt++;
}
}
else if(first < 0){
for(int i = 0; abs(a[i]) < -first; i++){
if(a[i] > 0){
cnt++;
flag = true;
}
}
for(int i = 0; i < n; i++){
if(abs(a[i]) > -first && flag && a[i] < 0)
cnt++;
}
}
cout << cnt+1;
return 0;
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复