码迷,mamicode.com
首页 > 其他好文 > 详细

PAT 乙级 1045

时间:2018-08-30 02:14:48      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:一个   条件   16px   max   push   std   bsp   tmp   style   

题目

    题目地址:PAT 乙级 1045

 

题解

    本题的解法比较巧妙,刚开始的试着用暴力求解,果不其然时间超限……

    变换思路,既然对于每个元素来说满足的条件是前小后大,那么对数组排序,对应的位置相等的即为题设要求的“可能主元”,但是还有一个条件要保证当前是从左向右遍历的最大值;总结一下两个条件:1. 排序后对应位置数字相等;2. 当前操作元素是从左向右遍历中的最大值

    同时还要注意,当输入n值为0时,除了需要输出“可能主元”的个数之外,还需要保留换行符‘\n’

 

代码

 1 #include <iostream>
 2 #include <algorithm>
 3 #include <vector>
 4 using namespace std;
 5 
 6 int main() {
 7     vector<int> num;
 8     vector<int> sortnum;
 9     vector<int> result;
10     int n = 0;
11     cin >> n;
12     while (n--) {
13         int tmp = 0;
14         cin >> tmp;
15         num.push_back(tmp);
16         sortnum.push_back(tmp);
17     }
18     sort(sortnum.begin(), sortnum.end());
19     int maxx = 0;
20     for (int i = 0; i < num.size(); i++) {
21         if (num[i] > maxx)
22             maxx = num[i];
23         if (num[i] == sortnum[i] && num[i] >= maxx)
24             result.push_back(sortnum[i]);
25     }
26     cout << result.size() << endl;
27     for (int i = 0; i < result.size(); i++) {
28         if (i != result.size() - 1)
29             cout << result[i] <<  ;
30         else
31             cout << result[i];
32     }
33     cout << endl;
34 
35     return 0;
36 }

 

PAT 乙级 1045

标签:一个   条件   16px   max   push   std   bsp   tmp   style   

原文地址:https://www.cnblogs.com/moujun1001/p/9557736.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!