首页 > 其他 > 详细

51nod——2502最多分成多少块

时间:2019-04-22 00:20:05      阅读:186      评论:0      收藏:0      [点我收藏+]

数据范围好小。。。

题目中没说要升序降序,不过样例解释里可以看出是要升序。

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 
 4 int a[11],b[11],visit[11];
 5 int main(){
 6     int n; cin>>n;
 7     for(int i=0;i<n;i++){
 8         cin>>a[i];
 9         b[i]=a[i];
10     }
11     sort(b,b+n);
12     for(int i=0;i<n;i++)
13         for(int j=0;j<n;j++)
14             if(a[i]==b[j]&&i!=j)
15                 for(int k=min(i,j);k<=max(i,j);k++) visit[k]=1;///把它现在的位置和它应该在的位置都标记,这个区间不能分
16 
17     int ans=0;
18     for(int i=0;i<n;i++)//为0的位置可以自成一块,不能分的部分成一块
19         if(visit[i]==0||(visit[i]==1&&visit[i+1]==0)) ans++;
20 
21     cout<<ans<<endl;
22     return 0;
23 }

 

51nod——2502最多分成多少块

原文:https://www.cnblogs.com/noobimp/p/10747768.html

(2)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!