排序子序列

链接:https://www.nowcoder.com/questionTerminal/2d3f6ddd82da445d804c95db22dcc471?orderByHotValue=1&page=1&onlyReference=false
来源:牛客网

       牛牛定义排序子序列为一个数组中一段连续的子序列,并且这段子序列是非递增或者非递减排序的。牛牛有一个长度为n的整数数组A,他现在有一个任务是把数组A分为若干段排序子序列,牛牛想知道他最少可以把这个数组分为几段排序子序列.
如样例所示,牛牛可以把数组A划分为[1,2,3]和[2,2,1]两个排序子序列,至少需要划分为2个排序子序列,所以输出2。
【题目解析】
       求解排序子序列,非递减就是a[i]<=a[i+1],递减就是a[i]>a[i+1],非递增就是a[i]>=a[i+1],递增就是a[i]<a[i+1]。
【解题思路】
       依次比较整个数组;a[i+1]>a[i],,则进入非递减序列判断,直到遍历到下一个值不大于等于为止count++,然后进行下一位 置的判断; a[i+1]<a[i],则进入非递增序列判断,直到遍历到下一个值不小于等于为止count++,然后进行下一位 置的判断 。a[i+1] == a[i]不进行操作,++i进行下一位置遍历,因为相等既可以属于非递增序列,也可以属于非递减 序列。
       整个过程以a[i+1]与a[i]进行比较,为了避免越界,数组定义为n+1个,同时给a[n] = 0;

#include<iostream>
#include<vector>
using namespace std;
int main(){
	int n;
	cin>>n;
	vector<int> a;
	a.resize(n+1);
	a[n]=0;
	int i=0
	for(i=0;i<n;i++)
		cin>>a[i];
   	i=0;
   	int count=0;
   	while(i<n){
   		if(a[i]>a[i+1]){
			while(i<n&&a[i]>=a[i+1])
				i++;
			count++;
			i++;
		}
		else if(a[i]==a[i+1]){
			i++;
		}
		else{
			while(i<n&&a[i]<=a[i+1])
				i++;
			count++;
			i++;
		}
   	}
   	cout<<count<<endl;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值