标签:
三道编程题在60分钟内做出来并不容易,加油吧
这题做出来容易,但在规定的时间内跑出结果并不容易,参考网友的答案:
#include<iostream> #include<string> using namespace std; bool isCap(char c) { if (c >= ‘A‘ && c <= ‘Z‘) return true; else return false; } //用位运算交换 void mSwap(char &a, char &b) { if (a != b) { a ^= b; b ^= a; a ^= b; } } int main() { string s; while (cin >> s) { int len = s.size(); int end = len; for (int i = 0; i<end; ++i) { if (isCap(s[i])) { int j = i; for (; j<len- 1; ++j) mSwap(s[j], s[j + 1]); --end;//精华! --i; } } cout << s <<endl; } return 0; }
思路:
void process(vector<int>& vec, int num) { int max=0, min=0; unordered_map<int, int>num_count; if (num > 1) { sort(vec.begin(), vec.end()); //如果全部元素相同,直接输出结果 if (*vec.begin() == *(vec.end() - 1)) { max = num*(num - 1) / 2; min = max; } else { for (auto it = vec.begin(); it != vec.end(); it++) { num_count[*it]++; } //计算最小差个数 for (const auto &data : num_count) { //如果数字个数超过1,则最小差为0,遍历并统计map中大于1的个数。 if (data.second > 1) min += data.second*(data.second - 1) / 2; } //如果数字无重复,最小差(绝对值)为排序数组相邻元素的差 if (min == 0) { int min_data = INT_MAX; for (auto it = vec.begin(); it != vec.end()-1; it++) { if (min_data > *(it + 1) - *it) min_data = *(it + 1) - *it; } for (auto it = vec.begin(); it != vec.end() - 1; it++) { if (min_data == *(it + 1) - *it) min++; } } //计算最大差个数,用最大值个数*最小值个数 int m1 = 1, m2 = 1; for (auto it = vec.begin(); it != vec.end() - 1; it++) { if (*it != *(it + 1)) break; m1++; } for (auto it = vec.rbegin(); it != vec.rend() - 1; it++) { if (*it != *(it + 1)) break; m2++; } max = m1*m2; } } cout << min << " " << max; } int main() { int num; while (cin >> num) { vector<int> vec(num); int temp; for (int i = 0; i < num; i++) { cin >> temp; vec.push_back(temp); } process(vec, num); cout << endl; } return 0; }
标签:
原文地址:http://www.cnblogs.com/573177885qq/p/5850055.html