原题链接:蓝桥杯历届试题-蚂蚁感冒
解题思路:
注意事项:
参考代码:
#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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复