POJ1363

本文介绍如何使用C++实现结构体及其内部数组与整数数组的比较功能,通过自定义比较函数来判断两个结构体是否相等。
#include<iostream>
using namespace std;

struct node {
	int sk[1050];
	int p;
};
int N,s[1050],num[1050];

bool cmp(node sta,int s[],int n){
	int top=1;
	bool flag=1;
	for(int i=0;i<n;i++){
		while(1){
			if(top<=n && s[i]==num[top]) {top++;break;}
			else if(sta.p>=0 && sta.sk[sta.p]==s[i]){sta.p--;break;}
			else if(s[i]>num[top]){
				sta.p++;
				sta.sk[sta.p]=num[top++];
			}
			else{
				flag = 0;
				break;
			}
		}
		if(!flag) break;
	}

	return flag;
}

void clear(node &s){
	s.p=-1;
}

int main(){
	node sta;
	for(int i=0;i<1010;i++) num[i]=i;
	while(cin>>N && N){
		while(1){
			clear(sta);
			for(int i = 0 ; i < N ; i++){
				cin>>s[i];
				if(!s[i])break;
			}
			if(!s[0]) break;
			if(cmp(sta,s,N)) cout<<"YES"<<endl;
			else cout<<"NO"<<endl;
		}
		cout<<endl;
	}
	return 0;
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值