vector基础2

给出两个int型的vector对象,编写程序判断一个对象是否是另一个对象的前缀。如果两个vector对象的长度不相同,假设较短的vector对象长度为n,则只对这两个对象的前面n个元素做比较。例如,对于(0,1,2)和(0,1,2,3,5,8)这两个vector,你的程序应该返回true

int main()
{   int ival;
	vector<int> ivec1;
	vector<int> ivec2;
	cout<<"vector1:"<<endl;
	cin>>ival;
	while(ival!=32767)
	{
 	ivec1.push_back(ival);
	cin>>ival;
	}
	cout<<"vector2:"<<endl;
	cin>>ival;
	while(ival!=32767)
	{
    ivec2.push_back(ival);
	cin>>ival;
	}
	vector<int>::size_type size1,size2;
	size1=ivec1.size();
	size2=ivec2.size();
	bool result=true;
		for(vector<int>::size_type id=0;id!=(size1<size2?size1:size2);++id)
	{
	    if(ivec1[id]!=ivec2[id])
		result=false;
			break;
	  }
		if(result)
          if (size1<size2)
			  cout<< "ivec1 is the prefix of ivec2"<<endl;
		  else if(size1==size2)
			  cout<<"ivec1 is equal to ivec2"<<endl;
		  else
			  cout<<"ivec2 is the prefix of ivec1"<<endl;
		else
			cout<<"no vector is the prefix of the other"<<endl;
	
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值