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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 15-6(0).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()+4;}
	ht_sz height()const{return p->height()+4;}
	void display(std::ostream&,ht_sz,bool)const;
};

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(),'*');
		}
		else if(row==1||row==height()-2)
		{
			//second from top or bottom row
			os<<"*";
			pad(os,1,width()-1);
			os<<"*";
		}
		else
		{
			//interior row
			os<<"* ";
			p->display(os,row-2,true);
			os<<" *";
		}
	}
}


//////////////////////////////////////////////////////////////////////////////////
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);
	for(Vec<Str>::size_type i=0;i!=v.size();++i)
		cout<<v[i]<<endl;

	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  <<  frame(hcat(s, vcat(r, q))) << endl;
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
看电影不卡的网站| 欧美经典一区二区| 欧美亚洲尤物久久| 97精品国产97久久久久久久久久久久| 青青草91视频| 国产一区二区女| 成人黄色国产精品网站大全在线免费观看| 亚洲aaa精品| 色哟哟一区二区| 国产专区综合网| www.视频一区| 欧美日韩小视频| 日韩一区二区三区视频| 欧美一级黄色片| 国产欧美日本一区视频| 亚洲精品国产一区二区三区四区在线| 亚洲欧美日韩中文播放| 日日摸夜夜添夜夜添亚洲女人| 另类专区欧美蜜桃臀第一页| 成人高清免费观看| 欧美一卡2卡三卡4卡5免费| 欧美韩日一区二区三区四区| 日精品一区二区| 大尺度一区二区| 欧美一区二区美女| 亚洲男人电影天堂| 国产成人免费在线| 欧美精品乱码久久久久久| 国产精品久久久久久久久免费丝袜 | 在线亚洲高清视频| 国产午夜亚洲精品理论片色戒| 一二三四区精品视频| 国产精品亚洲一区二区三区妖精| 91久久线看在观草草青青| 国产精品色在线观看| 国产一区美女在线| 日韩免费观看2025年上映的电影| 亚洲九九爱视频| 99精品欧美一区二区蜜桃免费| 亚洲精品一区二区三区香蕉| 日韩一区欧美二区| 欧美在线|欧美| 亚洲午夜三级在线| 欧美三级电影在线看| 亚洲综合色成人| 欧美日韩一级片在线观看| 亚洲精选视频免费看| 色老头久久综合| 亚洲国产乱码最新视频 | 亚洲欧洲av色图| 成人sese在线| 亚洲精品国产视频| 欧美四级电影网| 美女高潮久久久| 国产精品天干天干在观线| 成人av电影免费在线播放| 一区二区三区在线看| 欧美剧在线免费观看网站| 久久99精品国产| 一区二区三区中文免费| 欧美一级电影网站| 97成人超碰视| 精品一区二区三区的国产在线播放| 久久人人97超碰com| 色综合中文字幕| 久久电影网站中文字幕| 欧美激情综合五月色丁香小说| 一区二区三区在线视频免费 | 欧美精品成人一区二区三区四区| 日韩高清在线一区| 欧美激情一区二区三区四区| 制服丝袜成人动漫| a4yy欧美一区二区三区| 麻豆国产精品一区二区三区 | 97超碰欧美中文字幕| 激情综合色丁香一区二区| 亚洲一区av在线| 中文字幕日韩一区| 国产精品无人区| 精品国产伦理网| 欧美成人在线直播| 欧美大片在线观看一区二区| 欧美精品乱码久久久久久| 在线免费一区三区| 91蜜桃在线免费视频| 成人99免费视频| 国产成人午夜视频| 成人涩涩免费视频| 成人精品国产一区二区4080| 国产在线不卡视频| 国产69精品久久久久777| 成人性生交大片免费| 成人在线综合网站| 91小视频在线免费看| 91蜜桃视频在线| 在线不卡一区二区| 精品久久久久一区二区国产| 久久亚洲二区三区| 亚洲欧美在线高清| 亚洲电影中文字幕在线观看| 日本欧美大码aⅴ在线播放| 丝袜亚洲另类欧美| 高清成人免费视频| 一本到不卡免费一区二区| 欧美伦理电影网| 国产三级欧美三级日产三级99| 欧美国产一区二区| 日韩中文字幕不卡| 成人av网站在线观看免费| 欧美亚洲一区二区在线观看| 精品毛片乱码1区2区3区| 一区二区三区资源| 国产98色在线|日韩| 在线成人免费观看| 中文字幕一区二区在线观看| 性欧美疯狂xxxxbbbb| 国产午夜亚洲精品不卡| 亚洲精选一二三| 国产99久久久精品| 日韩欧美自拍偷拍| 亚洲天天做日日做天天谢日日欢| 亚洲h在线观看| 成人高清免费在线播放| 日韩亚洲欧美一区| 亚洲女子a中天字幕| 欧美日韩一区二区三区四区五区| 欧美精品一区二区三| 亚洲成人av一区二区三区| 日韩—二三区免费观看av| 99re热视频这里只精品| 欧美α欧美αv大片| 亚洲日本护士毛茸茸| 国产高清亚洲一区| 日韩一级片网站| 日韩av二区在线播放| 欧美日韩免费观看一区三区| 成人欧美一区二区三区| 国产精品1区二区.| 在线精品国精品国产尤物884a| 日韩成人免费看| 成人小视频免费在线观看| www.亚洲精品| 国产亚洲欧洲997久久综合| 麻豆91精品视频| 欧美一级高清片| 国产剧情av麻豆香蕉精品| 欧美一区二区黄| 国产精品系列在线观看| 欧美激情在线看| 不卡免费追剧大全电视剧网站| 国产日产欧美一区| 成人免费精品视频| 国产欧美一区二区精品性| 国产精品一区一区| 亚洲欧美在线高清| 91.麻豆视频| 国产成a人亚洲精品| 国产欧美日韩麻豆91| 色综合婷婷久久| 老司机精品视频一区二区三区| 日韩精品一区二区三区四区| 久久精品国产99国产| 欧美韩日一区二区三区| 91丨九色丨蝌蚪富婆spa| 亚洲成人激情av| 国产精品美女久久久久久久久久久| www.日韩av| 国产精品亚洲成人| 亚洲一区二区在线视频| 国产精品久久久久久久蜜臀| 欧美乱妇一区二区三区不卡视频| 国产精品一线二线三线| 亚洲午夜羞羞片| 亚洲国产精品av| 久久夜色精品国产噜噜av| 欧美在线一区二区三区| 风间由美中文字幕在线看视频国产欧美| 国产精品美女视频| 久久嫩草精品久久久精品一| 在线看日本不卡| 99久免费精品视频在线观看| 韩国一区二区在线观看| 国产精品久久久久精k8| 久久久亚洲国产美女国产盗摄 | 麻豆成人免费电影| 午夜电影网一区| 亚洲va天堂va国产va久| 亚洲网友自拍偷拍| 亚洲一区免费视频| 亚洲福利国产精品| 亚洲三级在线观看| 一区二区三区免费看视频| 亚洲精品国产第一综合99久久| 国产精品污www在线观看| 欧美激情一区二区三区蜜桃视频| 欧美激情一区三区| 国产精品高潮呻吟久久| 亚洲国产日韩综合久久精品| 亚洲第一主播视频| 九九精品一区二区|