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

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

?? query.h

?? c++ primer 經典書籍還有習題和答案,非常實用
?? H
字號:
#ifndef QUERY_H_
#define QUERY_H_

#include <vector>
#include <iostream.h>
#include <set>
#include <string>
#include <utility>

typedef pair< short, short > location;

class Query {
public:
	virtual ~Query(){ delete _solution; }

	virtual void eval() = 0;
	virtual Query *clone() const = 0;
	virtual ostream& print( ostream &os ) const = 0;
	virtual bool add_op( Query* ) { return true; }
	virtual void display_solution( ostream &os = cout, int tabcnt = 0 );
	
	Query& operator=( const Query& );
	void  handle_tab( ostream &os, int tabcnt ) const;
	const set< short,less<short>,allocator >    *solution();
	const vector< location, allocator > *locations() const { return &_loc; }

	void lparen( short lp ) { _lparen = lp; }
	void rparen( short rp ) { _rparen = rp; }

	short lparen() { return _lparen; }
	short rparen() { return _rparen; }

	void print_lparen( short cnt, ostream& os ) const;
	void print_rparen( short cnt, ostream& os ) const;

	void display_partial_solution();

protected:
	// copy constructor and copy assignment operator?
	Query() : _lparen( 0 ), _rparen( 0 ), _solution( 0 ) {}
	Query( const Query &rhs )
		: _loc( rhs._loc ), _solution( 0 ),
		  _lparen( rhs._lparen ), _rparen( rhs._rparen )
	{}

	Query( const vector<location, allocator> &loc )
		: _loc( loc ), _solution( 0 ), 
		  _lparen( 0 ), _rparen( 0 ) 
	{}

	set<short,less<short>,allocator>* 
		_vec2set( const vector<location,allocator>* );

	short                             _lparen;
	short                             _rparen;

	vector<location,allocator>        _loc; 
	set<short,less<short>,allocator> *_solution;
};

inline ostream&
operator<<( ostream &os, const Query &q ) { return q.print( os ); }

class NameQuery : public Query {
public:
	NameQuery( string name ) :  _name( name ) {}
	NameQuery( string name, const vector<location, allocator> &loc )
		 : Query( loc ), _name( name ) {}

	virtual void eval(); 
	virtual ostream& print( ostream &os ) const;
	virtual void display_solution( ostream &os = cout, int tabcnt = 0 );
	virtual Query *clone() const
		{ return new NameQuery( *this ); }
	
	string name() const { return _name; }
protected:
	string _name;
};

class NotQuery : public Query {
public:
	NotQuery( Query *op = 0 ) : _op( op ) {}
	NotQuery( const NotQuery& );
	~NotQuery() { delete _op; }

	virtual void eval(); 
	virtual ostream& print( ostream &os ) const;
	virtual bool add_op( Query* );
	virtual void display_solution( ostream &os = cout, int tabcnt = 0 );
	virtual Query *clone() const;
	
	NotQuery &operator=( const NotQuery& );
	const Query *op() const { return _op; }
	static void all_locs( const vector< location, allocator > *ploc ) 
		        { if ( !_all_locs ) _all_locs = ploc; }
protected:
	Query *_op;
	static const vector< location, allocator > *_all_locs;
};

class OrQuery : public Query {
public:
	OrQuery( Query *lop = 0, Query *rop = 0 ) 
		: _lop( lop ), _rop( rop ) {}

	OrQuery( const OrQuery& );
	~OrQuery() { delete _lop; delete _rop; }

	OrQuery& operator=( const OrQuery& );

	virtual void eval(); 
	virtual ostream& print( ostream &os ) const;
	virtual bool add_op( Query* );
	virtual void display_solution( ostream &os=cout, int tabcnt=0 );
	virtual Query* clone() const;
	
	const Query *rop() const { return _rop; }
	const Query *lop() const { return _lop; }

protected:
	Query *_lop;
	Query *_rop;
};

class AndQuery : public Query {
public:
	AndQuery( Query *lop = 0, Query *rop = 0 ) 
		: _lop( lop ), _rop( rop ) {}
	~AndQuery() { delete _lop; delete _rop; }

	AndQuery( const AndQuery& );
	AndQuery& operator=( const AndQuery& );

	virtual void eval(); 
	virtual ostream& print( ostream &os ) const;
	virtual bool add_op( Query* );
	virtual void display_solution( ostream &os=cout, int tabcnt=0 );
	virtual Query* clone() const;
	
	const Query *rop() const { return _rop; }
	const Query *lop() const { return _lop; }

	static void max_col( const vector< int, allocator > *pcol )
			{ if ( !_max_col ) _max_col = pcol; }

protected:
	Query *_lop;
	Query *_rop;
	static const vector< int, allocator > *_max_col;
};

class less_than_pair {
public:
	bool operator()( location loc1, location loc2 )
	{
		return (( loc1.first < loc2.first ) ||
			( loc1.first == loc2.first ) &&
			( loc1.second < loc2.second ));
	}
};

inline Query&
Query::
operator=( const Query &rhs )
{
        if ( &rhs != this )
        {
                _lparen = rhs._lparen;
                _rparen = rhs._rparen;
                _loc = rhs._loc;

                delete _solution;

                _solution = 0;
        }

        return *this;
};

inline 
const set< short, less<short>,allocator >*
Query::
solution() 
{
	if ( !_solution ) 
		_solution = _vec2set( &_loc );
	return _solution;
}

inline void 
Query::
display_partial_solution() 
{
	cout << "\t"  << *this
	     << " ( " << solution()->size() 
	     << " ) lines match" << endl;
}

inline NotQuery&
NotQuery:: 
operator=( const NotQuery &rhs )
{
	if ( &rhs != this )
	{
		this->Query::operator=( rhs );
		// delete _op;
		_op = rhs._op->clone();
	}

	return *this;
};

inline NotQuery::
NotQuery( const NotQuery &rhs )
	: Query( rhs )
{
	_op = rhs._op->clone();
};

inline AndQuery&
AndQuery::
operator=( const AndQuery &rhs )
{
        if ( &rhs != this )
        {
                this->Query::operator=( rhs );
                _lop = rhs._lop->clone();
                _rop = rhs._rop->clone();
        }

        return *this;
};

inline
AndQuery::
AndQuery( const AndQuery &rhs )
        : Query( rhs )
{
        _lop = rhs._lop->clone();
        _rop = rhs._rop->clone();
};

inline OrQuery&
OrQuery::
operator=( const OrQuery &rhs )
{
        if ( &rhs != this )
        {
                this->Query::operator=( rhs );
                _lop = rhs._lop->clone();
                _rop = rhs._rop->clone();
        }

        return *this;
};

inline OrQuery::
OrQuery( const OrQuery &rhs )
        : Query( rhs )
{
        _lop = rhs._lop->clone();
        _rop = rhs._rop->clone();
};

inline bool
AndQuery::
add_op( Query *op )
{
	bool status = false;
	if ( !_lop ) {
		_lop = op; status = true;
	}
	else
	if ( ! _rop ) {
		_rop = op; status = true; 
	}
	return status;
}

inline bool
OrQuery::
add_op( Query *op )
{
	bool status = false;
	if ( !_lop ) {
		_lop = op; status = true;
	}
	else
	if ( ! _rop ) {
		_rop = op; status = true; 
	}
	return status;
}

inline bool
NotQuery::
add_op( Query *op )
{
	bool status = false;
	if ( !_op ) {
		_op = op; status = true;
	}
	return status;
}

inline void
AndQuery::
display_solution( ostream &os, int tabcnt )
{
	handle_tab( os, tabcnt );
	os << "&& solution line set: ";
	Query::display_solution( os, 0 );
	_lop->display_solution( os, tabcnt+1 );
	_rop->display_solution( os, tabcnt+1 );
}

inline void
OrQuery::
display_solution( ostream &os, int tabcnt )
{
	handle_tab( os, tabcnt );
	os << "|| solution line set: ";
	Query::display_solution( os, 0 );
	_lop->display_solution( os, tabcnt+1 );
	_rop->display_solution( os, tabcnt+1 );
}

inline void
NotQuery::
display_solution( ostream &os, int tabcnt )
{
	handle_tab( os, tabcnt );
	os << "! solution line set: ";
	Query::display_solution( os, 0 );
	_op->display_solution( os, tabcnt+1 );
}

inline void
NameQuery::
display_solution( ostream &os, int tabcnt )
{
	handle_tab( os, tabcnt );
	os << _name << " solution line set: ";
	Query::display_solution( os, 0 );
}

inline ostream&
AndQuery::
print( ostream &os ) const
{
	if ( _lparen ) 
	     print_lparen( _lparen, os );

	_lop->print( os );
	os << " && ";
	_rop->print( os );

	if ( _rparen ) 
	     print_rparen( _rparen, os );

	return os;
}

inline ostream&
OrQuery::
print( ostream &os ) const
{
        if ( _lparen )
             print_lparen( _lparen, os );

	_lop->print( os );
	os << " || ";
	_rop->print( os );

        if ( _rparen )
             print_rparen( _rparen, os );

	return os;
}

inline ostream&
NotQuery::
print( ostream &os ) const
{
	os << " ! ";

        if ( _lparen )
             print_lparen( _lparen, os );

	_op->print( os );

        if ( _rparen )
             print_rparen( _rparen, os );

	return os;
}

inline ostream&
NameQuery::
print( ostream &os ) const
{
        if ( _lparen )
             print_lparen( _lparen, os );

	os << _name;

        if ( _rparen )
             print_rparen( _rparen, os );

	return os;
}

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
337p日本欧洲亚洲大胆精品 | 欧美日韩一区精品| 91视频.com| 成人avav影音| 99re热视频精品| 91视频观看免费| 欧美在线综合视频| 欧美吞精做爰啪啪高潮| 欧美r级电影在线观看| 欧美一级精品在线| 日韩一区二区免费视频| 精品久久免费看| 国产天堂亚洲国产碰碰| 久久精品亚洲国产奇米99| 欧美国产一区视频在线观看| 国产精品毛片久久久久久| 亚洲欧美综合另类在线卡通| 一区二区在线观看视频| 亚洲国产成人va在线观看天堂| 午夜精品一区二区三区电影天堂| 奇米色777欧美一区二区| 国产最新精品免费| 成人精品一区二区三区中文字幕 | 日本一区二区三区四区| 国产精品网站导航| 尤物av一区二区| 男女性色大片免费观看一区二区| 韩国女主播一区| 成人黄色一级视频| 欧美午夜在线一二页| 日韩精品中文字幕在线不卡尤物| 国产丝袜欧美中文另类| 亚洲蜜臀av乱码久久精品| 日韩av中文在线观看| 国产精品一级片在线观看| heyzo一本久久综合| 欧美欧美欧美欧美| 国产欧美日本一区二区三区| 一区二区三区丝袜| 青青草国产成人99久久| 国产夫妻精品视频| 欧美日韩视频一区二区| 国产夜色精品一区二区av| 亚洲欧美一区二区不卡| 免费美女久久99| 91视频你懂的| 26uuu亚洲婷婷狠狠天堂| 亚洲欧美成人一区二区三区| 免费成人av在线播放| 91美女片黄在线| 精品av久久707| 亚洲综合激情小说| 国产精品888| 欧美日韩精品欧美日韩精品一综合| 2023国产精品| 午夜精品久久一牛影视| 成人开心网精品视频| 91精品蜜臀在线一区尤物| 亚洲三级在线观看| 国产成人自拍高清视频在线免费播放| 欧美在线观看视频在线| 国产欧美中文在线| 日本免费新一区视频| 色94色欧美sute亚洲线路一ni| 精品乱码亚洲一区二区不卡| 亚洲综合男人的天堂| 成人高清免费观看| 精品美女被调教视频大全网站| 亚洲一区二区三区四区不卡| 国产宾馆实践打屁股91| 91精品国产欧美日韩| 国产欧美日韩综合| 成人做爰69片免费看网站| 在线观看av一区二区| 欧美韩国日本一区| 蜜桃视频在线一区| 色香蕉成人二区免费| 7777精品伊人久久久大香线蕉超级流畅| 国产无一区二区| 蜜臀av一级做a爰片久久| 欧美色倩网站大全免费| 日本一区二区成人在线| 国产激情一区二区三区四区| 欧美色精品在线视频| 亚洲精品视频在线看| 国产美女精品人人做人人爽| 日韩一区二区三区四区| 一个色综合av| 在线观看不卡一区| 国产精品夫妻自拍| 国产一区二区三区久久悠悠色av| 91久久一区二区| 国产精品理论片在线观看| 人人精品人人爱| 欧美日韩国产影片| 亚洲成a人在线观看| 成人app下载| 国产精品国产三级国产aⅴ入口| 精品一区二区三区蜜桃| 日韩免费看的电影| 日韩一区精品视频| 在线免费精品视频| 亚洲码国产岛国毛片在线| aaa欧美日韩| 中文字幕中文字幕在线一区| 成人做爰69片免费看网站| 久久久不卡影院| 国产成人精品午夜视频免费| 精品福利在线导航| 国产91高潮流白浆在线麻豆| 国产欧美日本一区视频| 白白色 亚洲乱淫| 国产精品青草综合久久久久99| 国产91高潮流白浆在线麻豆| 精品国产髙清在线看国产毛片| 美女视频免费一区| 精品国产人成亚洲区| 国产成人综合在线观看| 久久色.com| 91啪亚洲精品| 亚洲视频 欧洲视频| 欧美私模裸体表演在线观看| 亚洲一区在线电影| 日韩欧美一区二区免费| 激情五月激情综合网| 亚洲国产高清在线| 国产激情视频一区二区三区欧美| 国产精品久久久久久久久晋中| 精品久久久久久久人人人人传媒| 国产一区二区三区免费在线观看| 国产精品免费aⅴ片在线观看| 99精品视频一区二区三区| 亚洲国产日韩精品| 制服丝袜日韩国产| 国产激情精品久久久第一区二区| 欧美激情一区二区三区在线| 欧美做爰猛烈大尺度电影无法无天| 亚洲成人av免费| 国产色婷婷亚洲99精品小说| 91视频在线观看| 精品午夜久久福利影院| 久久久久99精品一区| 欧美综合一区二区| 麻豆久久一区二区| 中文字幕一区二| 日韩欧美亚洲一区二区| 丁香桃色午夜亚洲一区二区三区| 亚洲成人黄色小说| 日韩视频一区在线观看| 久久精品视频网| 成人免费观看男女羞羞视频| 午夜精品一区二区三区三上悠亚| 精品少妇一区二区三区免费观看| 91美女在线观看| 男女视频一区二区| 一色桃子久久精品亚洲| 日韩一区二区电影在线| 懂色一区二区三区免费观看| 亚洲国产综合91精品麻豆| 欧美精品一区二区三区视频| 91麻豆精品秘密| 国产精品夜夜嗨| 亚洲综合色区另类av| 中文字幕欧美日韩一区| 色悠久久久久综合欧美99| 国产精一区二区三区| 五月天视频一区| 国产精品久久久久久亚洲毛片 | 国产 日韩 欧美大片| 亚洲一区在线观看免费观看电影高清 | 亚洲欧洲另类国产综合| 精品国产凹凸成av人导航| 在线免费观看日本一区| 成人丝袜高跟foot| 亚洲一区二区在线观看视频| 中文字幕乱码久久午夜不卡| 欧美zozozo| 在线观看成人小视频| av爱爱亚洲一区| 激情成人午夜视频| 午夜视频在线观看一区| 26uuu色噜噜精品一区二区| 波多野结衣亚洲| 久久精品噜噜噜成人88aⅴ| 亚洲一区二区av在线| 中文字幕va一区二区三区| 精品国产乱码久久久久久久| 精品视频在线看| 99视频精品全部免费在线| 国产在线视频一区二区三区| 亚洲精品综合在线| 亚洲免费观看在线视频| 欧美一级片在线观看| 欧美另类变人与禽xxxxx| 欧美亚洲丝袜传媒另类| aa级大片欧美| 91麻豆123| 白白色 亚洲乱淫| 91污片在线观看| 国产成人综合在线播放|