亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 15-2,3,4.cpp

?? Accelerated C++ 課后練習題 本人自己完成、可供參考
?? CPP
字號:
#include<iostream>
#include<memory> 
#include<iterator>
#include<string>
#include<vector>
using std::cout;
using std::endl;
using std::cin;

template <class T> class Vec
{
public:
	typedef T* iterator;
	typedef const T* const_iterator;
	typedef size_t size_type;
	typedef T value_type;

	Vec() { create(); }
	explicit Vec(size_type n,const T& t=T()) { create(n,t);}
	
	Vec(const Vec& v) { create(v.begin(),v.end()); }
	Vec& operator=(const Vec&);
	~Vec() { uncreate();}

	T& operator[](size_type i) { return data[i]; }
	const T& operator[](size_type i) const {return data[i];}

	void push_back(const T& t)
	{
		if(avail==limit)
			grow();
		unchecked_append(t);
	}

	iterator erase(iterator);
	void clear();

	size_type size() const {return avail-data;}

	iterator begin() { return data;}
	const_iterator begin() const { return data;}

	iterator end() { return avail;}
	const_iterator end() const { return avail; }
private:
	iterator data;		//first element in the Vec
	iterator avail;		//(one past) the last of element in the Vec
	iterator limit;		//(one past) the allocated menory

	//facilities for memory allocation
	std::allocator<T> alloc;	//object to handle memory allocation
	
	//allocation and initialize the underlying array
	void create();
	void create(size_type,const T&);
	void create(const_iterator, const_iterator);

	//destroy the element in the array and free the memory
	void uncreate();

	//support funcions for push_back
	void grow();
	void unchecked_append(const T&);

};

template<class T>
Vec<T>& Vec<T>::operator =(const Vec& rhs)
{
	//check for self-assignment
	if(&rhs!=this)
	{
		//free the array in the left-hand side
		uncreate();
		//copy elements from the right-hand to the left-hand side
		create(rhs.begin(),rhs.end());
	}
	return *this;
}
template <class T> void Vec<T>::create()
{
	data=avail=limit=0;
}
template <class T> void Vec<T>::create(size_type n, const T& val)
{
	data=alloc.allocate(n,0);
	limit=avail=data+n;
	std::uninitialized_fill(data,limit,val);
}
template <class T> 
void Vec<T>::create(const_iterator i,const_iterator j)
{
	data=alloc.allocate(j-i,0);
	limit=avail=std::uninitialized_copy(i,j,data);
}
template <class T> void Vec<T>::uncreate()
{
	if(data)
	{
		//destroy (in reverse orde) the elements that were constructed
		iterator it=avail;
		while(it!=data)
			alloc.destroy(--it);

		//return all the space that was allocated
		alloc.deallocate(data,limit-data);
	}
	//reset pointers to indicate that the Vec is empty again
	data=limit=avail=0;
}
template <class T> void Vec<T>::grow()
{
	//when growing, allocate twice as much space as currently in use
	size_type new_size=std::_MAX(2*(limit-data),ptrdiff_t(1));

	//allocate new space and copy existing elements to the new space
	iterator new_data=alloc.allocate(new_size,0);
	iterator new_avail=std::uninitialized_copy(data,avail,new_data);

	//return the old space
	uncreate();

	//reset pointers to point to the newly allocate space
	data=new_data;
	avail=new_avail;
	limit=data+new_size;
}
template <class T> void Vec<T>::unchecked_append(const T& val)
{
	alloc.construct(avail++,val);
}
template <class T> Vec<T>::iterator Vec<T>::erase(iterator i)
{
	std::copy(i+1,avail,i);
	--avail;
	return i;
}
template <class T> void Vec<T>::clear()
{
	uncreate();
}



template<class T> class Ptr
{
public:
	//to copy the object conditionally when needed
	void make_unique()
	{
		if(*refptr!=1)
		{
			--*refptr;
			refptr=new size_t(1);
			p=p?clone(p):0;
		}
	}

	Ptr():refptr(new size_t(1)),p(0){}
	Ptr(T* t):refptr(new size_t(1)),p(t){}
	Ptr(const Ptr& h):refptr(h.refptr),p(h.p){++*refptr;}

	Ptr& operator=(const Ptr&);
	~Ptr();
	operator bool() const { return p;}
	T& operator*() const;
	T* operator->() const;
private:
	T* p;
	size_t* refptr;
};
template<class T> 
T& Ptr<T>::operator *() const
{
	if(p)
		return *p;
	throw std::runtime_error("unbound Ptr");
}
template<class T> 
T* Ptr<T>::operator ->() const
{
	if(p)
		return p;
	throw std::runtime_error("unbound Ptr");
}
template<class T> 
Ptr<T>& Ptr<T>::operator =(const Ptr& rhs)
{
	++*rhs.refptr;
	//free the left-hand side, destorying pointers if appropriate
	if(--*refptr==0)
	{
		delete refptr;
		delete p;
	}

	//copy in values from the right-hand side
	refptr=rhs.refptr;
	p=rhs.p;
	return *this;
}
template<class T>
Ptr<T>::~Ptr()
{
	if(--*refptr==0)
	{
		delete refptr;
		delete p;
	}
}

Vec<char>* clone(const Vec<char>* vp)
{
    return new Vec<char>(*vp);
}

class Str
{
	friend std::istream& operator>>(std::istream&,Str&);
	friend std::istream& getline(std::istream&,Str&);
public:
	operator bool(){return size()!=0?true:false;}
	Str& operator+=(const Str& s)
	{
		data.make_unique();
		std::copy(s.data->begin(),s.data->end(),std::back_inserter(*data));
		return *this;
	}

	//interface as before
	typedef Vec<char>::size_type size_type;

	//constructors to creator Ptrs
	Str():data(new Vec<char>){}
	Str(const char* cp):data(new Vec<char>)
	{
		std::copy(cp,cp+strlen(cp),std::back_inserter(*data));
	}
	Str(size_type n,char c):data(new Vec<char>(n,c)){}
	template<class In>
	Str(In i,In j):data(new Vec<char>)
	{
		std::copy(i,j,std::back_inserter(*data));
	}

	//call mack_unique as necessary
	char& operator[](size_type i)
	{
		data.make_unique();
		return (*data)[i];
	}
	const char& operator[](size_type i)const{return (*data)[i];}
	size_type size()const{return data->size();}
	const Str substr(size_type i,size_type length) const
	{
		return Str(&(*data)[i],&(*data)[i]+length);	
	}

	const char* c_str() const;
	const char* c_date() const;
	const char* copy(char*,size_type) const;

	typedef Vec<char>::iterator iterator;
	typedef Vec<char>::const_iterator const_iterator;
	iterator begin(){return data->begin();}
	const_iterator begin() const {return data->begin();}
	iterator end(){return data->end();}
	const_iterator end() const {return data->end();}

private:
	//store a Ptr to a vector
	Ptr<Vec<char> > data;
};
std::ostream& operator<<(std::ostream& os, const Str& s)
{
	for(Str::size_type i=0;i<s.size();++i)
		os<<s[i];
	return os;
}
Str operator+(const Str& s,const Str& t)
{
	Str r=s;
	r+=t;
	return r;
}
std::istream& getline(std::istream& is,Str& s)
{
	//obliterate existing value (s)
	s.data->clear();

	//read and discard leading whitespace
	char c;
	while(is.get(c)&&isspace(c))
		;//nothing to do, except testing the condition
		//if still something to read, do so until next whitespace charactor
	if(is)
	{
		do
			s.data->push_back(c);	//compile error! data is private
		while(is.get(c)&&c!='\n');
	}
	return is;
}
const char* Str::copy(char* p,size_type n) const
{
	if(strlen(p)<n)
		throw "benefit!";
	else
	{
		std::copy(data->begin(),data->begin()+n,p);
		return p;
	}
}
const char* Str::c_str() const
{
	char* p=new char[size()];
	std::copy(data->begin(),data->end(),p);
	p[size()]=0;
	return p;
}
const char* Str::c_date() const
{
	char* p=new char[size()-1];
	std::copy(data->begin(),data->end(),p);
	return p;
}
Vec<Str> split(const Str& s)
{
	Vec<Str> ret;
	typedef Str::size_type string_size;
	string_size i=0;

	//ivarinant: we have processed characters [original value of i, i)
	while(i!=s.size())
	{
		//ignore leading blanks
		//invariant: characters in range [original i, current i) are all spaces
		while(i!=s.size()&&isspace(s[i]))
			++i;
		//find end of next word
		string_size j=i;
		//invariant: none of the characters in range [original j,current j)is a space
		while(j!=s.size()&&!isspace(s[j]))
			j++;
		//if we found some nonwhitespace characters
		if(i!=j)
		{
			//copy from s starting at i and taking j-i chars
			ret.push_back(s.substr(i,j-i));
			i=j;
		}
	}
	return ret;
}
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////

class Picture;

class Pic_base
{
	friend std::ostream& operator<<(std::ostream&,const Picture&);
	friend class Frame_Pic;
	friend class HCat_Pic;
	friend class VCat_Pic;
	friend class String_Pic;

	//no public interface
	typedef Vec<Str>::size_type ht_sz;
	typedef Str::size_type wd_sz;
 

	//this class is an abstract base class
	virtual wd_sz width() const=0;
	virtual ht_sz height() const=0;
	virtual void display(std::ostream&,ht_sz,bool) const=0;
protected:
	static void pad(std::ostream& os, wd_sz beg, wd_sz end)
	{
		while(beg!=end)
		{
			os<<" ";
			++beg;
		}
	}
};


class Picture 
{
	friend std::ostream& operator<<(std::ostream&,const Picture&);
	friend Picture frame(const Picture&);
	friend Picture hcat(const Picture&,const Picture&);
	friend Picture vcat(const Picture&,const Picture&);
public:
     Picture(const Vec<Str>& =Vec<Str>());
    
private:
	Picture(Pic_base* ptr):p(ptr){}
    Ptr<Pic_base> p;
};

////////////////////////////////////////////////////////////////////////////////////

class Frame_Pic:public Pic_base
{       
	friend Picture frame(const Picture&);
	Ptr<Pic_base> p;
	Frame_Pic(const Ptr<Pic_base>& pic):p(pic){}

	wd_sz width()const{return p->width()+8;}
	ht_sz height()const{return p->height()+4;}
	void display(std::ostream&,ht_sz,bool)const;
};


char ch;
void Frame_Pic::display(std::ostream& os,ht_sz row,bool do_pad)const
{
	if(row>=height())
	{
		//out of range
		if(do_pad)
			pad(os,0,width());
	}

	else
	{
		if(row==0||row==height()-1)
		{
			//top or bottom row
			os<<Str(width(),ch);
		}
		else if(row==1||row==height()-2)
		{
			//second from top or bottom row
			os<<Str(1,ch)+Str(" &");
			pad(os,1,(width()-5)/2);
			os<<"$";
			pad(os,(width()-5)/2+1,width()-5);
			os<<Str("& ")+Str(1,ch);
		}
		else
		{
			//interior row
			if(row==height()/2)
			{
				os<<Str(1,ch)+Str(" % ");
				p->display(os,row-2,true);
				os<<Str(" % ")+Str(1,ch);
			}
			else
			{
				os<<Str(1,ch)+Str("   ");
				p->display(os,row-2,true);
				os<<Str("   ")+Str(1,ch);
			}
		}
	}
}




//////////////////////////////////////////////////////////////////////////////////
class String_Pic:public Pic_base
{
	friend class Picture;
	Vec<Str> data;

	String_Pic(const Vec<Str>& v):data(v){};
	
	ht_sz height() const {return data.size();}
	wd_sz width() const;
	void display(std::ostream&,ht_sz,bool)const;
};
Pic_base::wd_sz String_Pic::width()const
{
	Pic_base::wd_sz n=0;
	for(Pic_base::ht_sz i=0;i!=data.size();++i)
		n=std::_MAX(n,data[i].size());
	return n;
}

void String_Pic::display(std::ostream& os, ht_sz row, bool do_pad)const
{
	wd_sz start=0;
	
	//write the row if we're still in range
	if(row<height())
	{
		os<<data[row];
		start=data[row].size();
	}

	//pad the output if necessary
	if(do_pad)
		pad(os,start,width());
}

/////////////////////////////////////////////////////////////////////////////////////

class VCat_Pic:public Pic_base
{
	friend Picture vcat(const Picture&,const Picture&);
	Ptr<Pic_base> top,bottom;
	VCat_Pic(const Ptr<Pic_base>& t,const Ptr<Pic_base>& b):top(t),bottom(b){}

	wd_sz width()const{return std::_MAX(top->width(),bottom->width());}
	ht_sz height()const{return std::_MAX(top->height(),bottom->height());}
	void display(std::ostream&,ht_sz,bool)const;
};

void VCat_Pic::display(std::ostream& os, ht_sz row, bool do_pad)const
{
	wd_sz w=0;
	if(row<top->height())
	{
		//we are in the top subpicture
		top->display(os,row,do_pad);
		w=top->width();
	}
	else if (row<height())
	{
		//we are in the bottom subpicture
		bottom->display(os,row-top->height(),do_pad);
		w=bottom->width();
	}
	if(do_pad)
		pad(os,w,width());
}
//////////////////////////////////////////////////////////////////////////////////

class HCat_Pic:public Pic_base
{
	friend Picture hcat(const Picture&,const Picture&);
	Ptr<Pic_base> left,right;
	HCat_Pic(const Ptr<Pic_base>& l,const Ptr<Pic_base>& r):left(l),right(r){}
	wd_sz width()const{return left->width()+right->width();}
	ht_sz height()const{return std::_MAX(left->height(),right->height());}
	void display(std::ostream&,ht_sz,bool)const;
};
void HCat_Pic::display(std::ostream& os,ht_sz row,bool do_pad)const
{
	left->display(os,row,do_pad||row<right->height());
	right->display(os,row,do_pad);
}

//////////////////////////////////////////////////////////////////////////////


Picture frame(const Picture& pic)
{
	return new Frame_Pic(pic.p);
}
Picture hcat(const Picture& l,const Picture& r)
{
	return new HCat_Pic(l.p,r.p);
}
Picture vcat(const Picture& t,const Picture& b)
{
	return new VCat_Pic(t.p,b.p);
}
//Picture::Picture(const Vec<Str>& v):p(new String_Pic(v)){}
std::ostream& operator<<(std::ostream& os,const Picture& picture)
{
	const Pic_base::ht_sz ht=picture.p->height();
	for(Pic_base::ht_sz i=0;i!=ht;++i)
	{
		picture.p->display(os,i,false);
		os<<endl;
	}
	return os;
}

Picture::Picture(const Vec<Str>& v):p(new String_Pic(v)){}

int main()
{
	Str str;
	getline(cin,str);
	cout<<str<<endl;
	Vec<Str> v;
	v=split(str);

		cout<<"specify what characters to use for these border characters"<<endl;
		cin>>ch;

	Picture p = v;
	cout<<p<<endl;
	Picture q = frame(p);
	cout<<q<<endl;
	Picture r = hcat(p, q) ;
	cout<<r<<endl;
	Picture s = vcat(q, r);
	    
		cout<<"specify what characters to use for these border characters"<<endl;
		cin>>ch;

	cout  <<  frame(hcat(s, vcat(r, q))) << endl;
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产高清精品在线| 国产a视频精品免费观看| 久久精品亚洲乱码伦伦中文 | 狠狠色狠狠色综合| 亚洲精品乱码久久久久久久久 | 欧美一级黄色大片| 99久久99久久综合| 国内精品国产成人| 日韩电影在线免费看| 亚洲欧洲三级电影| 久久蜜臀精品av| 日韩亚洲欧美成人一区| 一本色道久久加勒比精品 | 成人精品免费看| 精品一区二区三区在线观看 | 日韩精品一区二区三区视频在线观看 | 国产精品国产精品国产专区不蜜 | 中文字幕电影一区| 精品久久久久久亚洲综合网| 欧美年轻男男videosbes| 99久久国产综合色|国产精品| 韩国三级电影一区二区| 免费在线观看视频一区| 五月综合激情日本mⅴ| 一区二区三区国产精品| 国产精品进线69影院| 久久精品夜色噜噜亚洲aⅴ| 欧美成人video| 宅男噜噜噜66一区二区66| 欧美性猛交一区二区三区精品| 99re在线精品| 成人黄色小视频在线观看| 国产成都精品91一区二区三| 国产精品原创巨作av| 国内精品视频666| 国产麻豆视频一区二区| 国产精一品亚洲二区在线视频| 日韩专区一卡二卡| 日韩精品一卡二卡三卡四卡无卡| 亚洲高清不卡在线观看| 亚洲成人精品影院| 亚洲国产精品一区二区久久恐怖片| 亚洲在线免费播放| 亚洲国产一区在线观看| 首页国产欧美日韩丝袜| 麻豆一区二区三区| 久久精品国产亚洲aⅴ| 国产综合色视频| 高清不卡在线观看| 成人av网站免费| 色呦呦国产精品| 88在线观看91蜜桃国自产| 4438x亚洲最大成人网| 日韩情涩欧美日韩视频| 亚洲精品一区二区三区在线观看| 久久色.com| 亚洲欧洲在线观看av| 亚洲精品国产精品乱码不99 | av中文一区二区三区| 91丨九色丨蝌蚪丨老版| 欧美日韩中文国产| 精品少妇一区二区三区日产乱码| 久久久久久久久97黄色工厂| 欧美激情一区三区| 一区二区在线观看免费| 美女爽到高潮91| 99视频国产精品| 欧美精品123区| 国产午夜三级一区二区三| 亚洲欧美在线视频观看| 婷婷成人激情在线网| 国产精品自在在线| 色婷婷亚洲婷婷| 精品乱人伦小说| 亚洲色图.com| 久久国产精品99精品国产| av午夜精品一区二区三区| 在线播放视频一区| 国产女同性恋一区二区| 亚洲成a人在线观看| 国产精品亚洲综合一区在线观看| 欧洲一区二区三区免费视频| 欧美mv和日韩mv的网站| 一个色综合网站| 国产毛片一区二区| 欧美日韩国产中文| 国产精品美日韩| 免费在线观看一区| 一本色道久久综合亚洲aⅴ蜜桃| 精品欧美黑人一区二区三区| 亚洲毛片av在线| 国内精品免费在线观看| 欧美日韩亚洲综合| 国产精品乱码一区二区三区软件| 日本人妖一区二区| 色呦呦日韩精品| 日本一区二区成人| 看国产成人h片视频| 在线国产电影不卡| 国产精品女主播av| 精品一区二区三区视频在线观看 | 美腿丝袜在线亚洲一区 | 欧美一区二区久久久| 亚洲精品视频在线| 国产成人免费在线| 欧美成人在线直播| 香蕉成人啪国产精品视频综合网| eeuss鲁一区二区三区| 久久久久88色偷偷免费| 日韩在线一区二区| 欧美亚洲免费在线一区| 中文字幕一区三区| 国产suv精品一区二区883| 欧美一区二区精品| 日韩精品一二三区| 欧美色综合影院| 亚洲精品国产高清久久伦理二区| 成人精品高清在线| 中文字幕免费在线观看视频一区| 极品美女销魂一区二区三区| 欧美夫妻性生活| 性久久久久久久久久久久| 欧美中文字幕一区| 亚洲夂夂婷婷色拍ww47| 欧美亚洲国产怡红院影院| 亚洲欧美日韩中文字幕一区二区三区| 成人av资源在线| 国产精品麻豆一区二区| 成人福利视频在线看| 欧美国产在线观看| 成人国产亚洲欧美成人综合网| 国产亚洲欧美中文| 成人国产在线观看| 亚洲欧洲中文日韩久久av乱码| 成人免费福利片| 日韩一区有码在线| 91视频国产资源| 亚洲欧美一区二区三区国产精品 | 精品动漫一区二区三区在线观看| 男女男精品视频网| 精品粉嫩aⅴ一区二区三区四区| 国内精品久久久久影院薰衣草| 久久综合精品国产一区二区三区| 国产福利精品导航| 亚洲天堂精品在线观看| 欧美性猛交xxxxxxxx| 午夜影院久久久| 日韩丝袜情趣美女图片| 国产在线国偷精品产拍免费yy| 久久婷婷一区二区三区| 成人黄色777网| 亚洲一区二区三区视频在线播放 | 亚洲一卡二卡三卡四卡| 91精品在线观看入口| 狠狠色丁香久久婷婷综| 国产精品全国免费观看高清| 91美女福利视频| 日韩国产欧美在线视频| 久久久久久久久免费| 99r精品视频| 三级久久三级久久| 26uuu国产日韩综合| 成人精品国产免费网站| 亚洲成av人在线观看| 精品国产乱码久久久久久闺蜜| 国产成都精品91一区二区三| 亚洲欧美日本韩国| 91精品国产色综合久久不卡蜜臀| 国产一区视频导航| 中文字幕欧美一| 欧美一区二区三区四区久久| 国产乱妇无码大片在线观看| 亚洲精品美腿丝袜| 亚洲精品一区在线观看| 日本韩国精品一区二区在线观看| 免费人成在线不卡| 国产欧美日韩久久| 7777女厕盗摄久久久| 国产成人亚洲综合a∨婷婷图片| 一级做a爱片久久| 国产欧美日韩视频在线观看| 欧美日韩一区二区三区四区| 国产美女娇喘av呻吟久久| 亚洲国产视频在线| 国产欧美一区二区精品忘忧草| 欧美色视频一区| 成人永久看片免费视频天堂| 婷婷久久综合九色综合伊人色| 国产精品蜜臀在线观看| 日韩免费在线观看| 在线一区二区视频| 成人看片黄a免费看在线| 麻豆视频观看网址久久| 亚洲精品ww久久久久久p站| 久久久久久9999| 日韩一级二级三级精品视频| 色综合久久久久综合体桃花网| 久久av资源网| 午夜精品福利视频网站| 亚洲品质自拍视频|