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

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

?? s_main.cpp

?? c編譯器詞法分析程序源碼
?? CPP
字號:
/**************************************************
 * Essential C++ -- Stanley Lippman
 * Addison-Wesley 
 * ISBN 0-201-48518-4
 * homepage: www.objectwrite.com
 * email: slippman@objectwrite.com
 *************************************************/

#include <map>
#include <string>
#include <vector>
#include <utility>
#include <algorithm>
#include <iostream>
using namespace std;

// ******************************
// do i need to store the vector
// or can i access it through the ns element????
// ********************************

// various test programs
extern void prog1();
extern void prog2();
extern void prog3();

int main()
{
	// prog1();
	// prog2();
	prog3();

	return 0; // quiets vc++
}

typedef unsigned int uint;

template <typename seq_type>
class num_sequence;

template <typename seq_type>
ostream& operator<<( ostream &os, const num_sequence<seq_type> &ns );

template <typename seq_type>
class num_sequence {
public:
    typedef vector<unsigned int>::iterator iterator;

	num_sequence( int len=1, int bp=1 );
			 
	uint elem( int pos ) const;
	bool is_elem(  unsigned int ) const;
	int  pos_elem( unsigned int ) const;

    const char* what_am_i() const { return seq_type::what_am_i(); }
	static int  max_elems(){ return _max_elems; }
	ostream& print( ostream &os = cout ) const; 

	void set_position( int pos );
	void set_length( int pos );

	bool operator ==( const num_sequence& ) const;
    bool operator !=( const num_sequence& ) const;
	
    const vector<unsigned int>* sequence() const
		{ return _pelems; }

	iterator begin() const 
		 { return _pelems->begin()+_beg_pos-1; }

	iterator end() const 
		 { return _pelems->begin()+_beg_pos+_length; }

	int length()  const { return _length;  }
    int beg_pos() const { return _beg_pos; }

protected:
	void gen_elems( int pos ) const { _ns.gen_elems( pos ); }
	bool check_integrity( int pos, int size ) const;
	int _calc_pos( unsigned int elem ) const;

	seq_type		   _ns;
	int                _length; 	
    int                _beg_pos;  
	vector<uint>      *_pelems;
	static const int   _max_elems;
};

template <typename seq_type>
const int num_sequence<seq_type>::_max_elems = 1024;

template <typename seq_type>
ostream& 
operator<<( ostream &os, const num_sequence<seq_type> &ns )
{  
    return ns.print( os );
}

template <typename seq_type>
inline bool 
num_sequence<seq_type>::
operator==( const num_sequence &rhs ) const 
{
	return ( _beg_pos == rhs._beg_pos ) &&
		   ( _length  == rhs._length );
}

template <typename seq_type>
inline bool 
num_sequence<seq_type>::
operator !=( const num_sequence &rhs ) const 
	{ return ! ( *this == rhs ); }

template <typename seq_type>
inline void 
num_sequence<seq_type>::
set_position( int pos )
{
	if ( pos <= 0 || pos > _max_elems ){
		 cerr << "!! invalid position: " << pos 
			  << " setting pos to default value of 1\n"
			  << "If inadequate, invoke set_position(pos)\n";
		 pos = 1;
	}
	_beg_pos = pos;
}

template <typename seq_type>
inline void 
num_sequence<seq_type>::
set_length( int len )
{
	if ( len <= 0 || len + _beg_pos - 1 > _max_elems ){
		 cerr << "!! invalid length for this object: " << len 
			  << " setting length to default value of 1\n"
			  << "If inadequate, invoke set_length(len)\n";
	     len = 1;
	}
	_length = len;
}

template <typename seq_type>
num_sequence<seq_type>::
num_sequence( int beg_pos, int len )
	: _pelems( seq_type::elemset() )
{ 
	set_position( beg_pos ); 
	set_length( len ); 
}

template <typename seq_type>
uint num_sequence<seq_type>::
elem( int pos ) const 
{
	return ( ! check_integrity( pos, _pelems->size() ))
		     ? 0 : (*_pelems)[ pos-1 ];
}

template <typename seq_type>
bool num_sequence<seq_type>::
check_integrity( int pos, int size ) const
{
	if ( pos <= 0 || pos > max_elems() )
	{
		 cerr << "!! invalid position: " << pos
			  << " Cannot honor request\n";
		 return false;
	}

	if ( pos > size )
		 gen_elems( pos );

	return true;
}

template <typename seq_type>
ostream& num_sequence<seq_type>::
print( ostream &os ) const
{
		
	int elem_pos = _beg_pos-1;
	int end_pos = elem_pos + _length;

    if ( ! check_integrity( end_pos, _pelems->size() ))
			 return os;

     os << "( "
	    << _beg_pos << " , "
	    << _length << " ) ";
   
	while ( elem_pos < end_pos )
		     os << (*_pelems)[ elem_pos++ ] << ' ';

	return os;
}

// is_elem() returns true if the element passed in a valid element 
// in the object's sequence. For example, if the object represents 
// a fibonacci sequence { 1,1, 2, 3, 5, 8, 13, 21, 34, 45}, beginning 
// as position 3 for a length of 2, then
//    Obj.is_elem( 1 ); // false
//    Obj.is_elem( 3 ); // true
//    Obj.is_elem( 5 ); // false
//    Obj.is_elem( 4 ); // false

template <typename seq_type>
inline bool 
num_sequence<seq_type>::
is_elem( unsigned int elem ) const
{
	return ( ! check_integrity( _beg_pos, _length ))
		     ? false : binary_search( begin(), end(), elem );
}

// pos_elem() returns the position of an element within the sequence 
// independent of what the object's position and length. The object 
// simply is used to identify the sequence for which to return a position. 
// If the element value is invalid, return 0. For example, if the object 
// represents a fibonacci sequence, then
//     Obj.pos_elem( 1 ); // returns 1 - ignore duplicate
//     Obj.pos_elem( 32 ); // returns 9
//     Obj.pos_elem( very-large-instance ); // your choice
//     Obj.pos_elem( 4 ); // return 0

template <typename seq_type>
int num_sequence<seq_type>::
pos_elem( unsigned int elem ) const
{
	cout << "pos_elem( " << elem << " )\n";

	if ((*_pelems)[ _pelems->size()-1 ] < elem )
		 return _calc_pos( elem );

	iterator iter = find( _pelems->begin(), _pelems->end(), elem );
	return ( iter == _pelems->end() )
		     ? 0 
			 : distance( _pelems->begin(), iter )+1;
}

template <typename seq_type>
int num_sequence<seq_type>::
_calc_pos( unsigned int elem ) const
{
    // presumption is that check_integrity() has passed
	int pos = _pelems->size()-1;

    cout << "calc_pos invoked()!: elem: " << elem 
		 << " pos: " << pos 
		 << " at: "  << (*_pelems)[ pos ] 
		 << "\n";

	while (( pos < _max_elems ) && 
		   ( (*_pelems)[ pos ] < elem ))
	{
		   _ns.gen_elems( ++pos ); 
		   cout << " pos: " << pos 
		        << " at: "  << (*_pelems)[ pos ] << endl;
	}

	return (( pos < _max_elems ) && 
		   ((*_pelems)[pos] == elem )) ? pos+1 : 0;
}

class Fibonacci {
public:
   void  gen_elems( int pos ) const;
   static vector<uint>* elemset() { return &_elems; }
   static const char* what_am_i() { return "Fibonacci"; }

protected:
   static vector<uint> _elems;
};

class Pell {
public:
public:
   void  gen_elems( int pos ) const;
   static vector<uint>* elemset() { return &_elems; }
   static const char* what_am_i() { return "Pell"; }

protected:
   static vector<uint> _elems;
};

class Lucas {
public:
   void  gen_elems( int pos ) const;
   static vector<uint>* elemset() { return &_elems; }
   static const char* what_am_i() { return "Lucas"; }

protected:
   static vector<uint> _elems;
};

class Triangular {
public:
   void  gen_elems( int pos ) const;
   static vector<uint>* elemset() { return &_elems; }
   static const char* what_am_i() { return "Triangular"; }

protected:
   static vector<uint> _elems;
};

class Square {
public:
   void  gen_elems( int pos ) const;
   static vector<uint>* elemset() { return &_elems; }
   static const char* what_am_i() { return "Square"; }

protected:
   static vector<uint> _elems;
};

class Pentagonal {
public:
   void  gen_elems( int pos ) const;
   static vector<uint>* elemset() { return &_elems; }
   static const char* what_am_i() { return "Pentagonal"; }

protected:
   static vector<uint> _elems;
};

vector<uint> Fibonacci::_elems;
vector<uint> Pell::_elems;
vector<uint> Lucas::_elems;
vector<uint> Triangular::_elems;
vector<uint> Square::_elems;
vector<uint> Pentagonal::_elems;

template <typename seq_type>
inline void 
display( ostream &os, const num_sequence<seq_type> &ns, int pos )
{
	os << "The element at position " 
	   << pos            << " for the "
	   << ns.what_am_i() << " sequence is " 
	   << ns.elem( pos ) << endl;
}

template <typename seq_type>
inline void 
display( ostream &os, const num_sequence<seq_type> &ns, 
		 int pos, int elem_val )
{
	os << "The element at position " << pos 
	   << " for the "
	   << ns.what_am_i() 
	   << " sequence is " << elem_val << endl;
}

void prog1()
{
	const int pos = 8;

	num_sequence<Fibonacci> fib;	
	display( cout, fib, pos );

	num_sequence<Pell> pell;
	display( cout, pell, pos );

	num_sequence<Lucas> lucas;
	display( cout, lucas, pos );

	num_sequence<Triangular> trian;
	display( cout, trian, pos );
	
	num_sequence<Square> square;
	display( cout, square, pos );

	num_sequence<Pentagonal> penta;
    display( cout, penta, pos );
}

void prog2()
{
	num_sequence<Fibonacci>  fib( 1, 8 );
	cout << "fib: " << fib.what_am_i() << endl;
	num_sequence<Pell>       pell( 4, 6 );
	num_sequence<Lucas>      lucas( 7, 10 );
	num_sequence<Triangular> trian( 1, 12 );
	num_sequence<Square>     square( 6, 6 );
	num_sequence<Pentagonal> penta( 1, 8 );
	
	cout << "fib: "    << fib    << '\n'
	     << "pell: "   << pell   << '\n'
		 << "lucas: "  << lucas  << '\n'
		 << "trian: "  << trian  << '\n'
		 << "square: " << square << '\n'
		 << "penta: "  << penta  << endl;
};

template <typename seq_type>
void prog_3( seq_type ns, int elem_values )
{
	int elem_val = 0;
	const int pos = 8;
	const int find_pos = 14;

    elem_val = ns.elem( pos );
    display( cout, ns, pos, elem_val );
	cout << ns.what_am_i() << " : ( " 
		 << ns.beg_pos()   << ", "
		 << ns.length()    << " ) : "
		 << ns;
	cout << endl;

	ns.set_length( 12 );
	cout << ns << endl;

	cout << "num_sequence::is_elem() ";
	if ( ! ns.is_elem( elem_val ) ||
		   ns.is_elem( 2*elem_val ))
				 cout << "failed\n";
	else cout << "ok!\n";

	cout << "copy constructor and equality ";
	seq_type ns2 = ns;
	if ( ns != ns2 )
		 cout << "failed!\n";
	else cout << "ok!\n";

	ns2.set_position( 5 );
 
	int posit = ns.pos_elem( elem_val );
	if ( ns.pos_elem( elem_val ) != pos )
	     cout << "pos_elem() failed : " << posit << "\n";
	else cout << "pos_elem() -- ok: " << posit << "\n";

	posit = ns.pos_elem( elem_values );
    if ( posit != find_pos ) 
		 cout << "pos_elem(): not found but grown: failed: " 
			  << posit << " correct: " << find_pos << "\n";
    else cout << "pos_elem(): not found but grown: ok\n";

	cout << "about to print final ns vector: \n";
	ns.print();
	cout << endl;
		  
	cout << "ns2: should begin at position 5:\n" 
		 << ns2 << endl;
}

void prog3()
{
	int elem_values[] = 
		{ 377, 80782, 843, 105, 196, 287 };
	
	// for ( int ix = 0; ix < 6; ++ix ) // test all
	for ( int ix = 0; ix < 1; ++ix )    // test 1 at time
	{
		switch( ix ) {
		case 0: {
			num_sequence<Fibonacci> ns( 1,8 );
			prog_3( ns, elem_values[ix] );
			break;}
		case 1:{
			num_sequence<Pell> ns( 1,8 );
			prog_3( ns, elem_values[ix] );
			break;}
		case 2:{
			num_sequence<Lucas> ns( 1,8 );
			prog_3( ns, elem_values[ix] );
			break;}
		case 3:{
			num_sequence<Triangular> ns( 1,8 );
			prog_3( ns, elem_values[ix] );
			break;}
		case 4:{
			num_sequence<Square> ns( 1,8 );
			prog_3( ns, elem_values[ix] );
			break;}
		case 5:{
			num_sequence<Pentagonal> ns( 1,8 );
			prog_3( ns, elem_values[ix] );
			break;}
		default:
			return;
		}	
	}
}
	
void Fibonacci::
gen_elems( int pos ) const
{   
	if ( pos <= 0 || 
		 pos > num_sequence<Fibonacci>::max_elems() )
		       return;

    if ( _elems.empty() )
       { _elems.push_back( 1 ); _elems.push_back( 1 ); }

    if ( _elems.size() <= pos )
	{
		    int ix = _elems.size();
			int n_2 = _elems[ ix-2 ], 
				n_1 = _elems[ ix-1 ];

			int elem;
			for ( ; ix <= pos; ++ix ){
				    elem = n_2 + n_1; 
					// cout << "gen_elems: " << elem << endl;
					_elems.push_back( elem );
					n_2 = n_1; n_1 = elem;
			}
	 }
}
   
void Pell::
gen_elems( int pos ) const    
{    
	if ( pos <= 0 || 
		 pos > num_sequence<Pell>::max_elems() )
		       return;

    if ( _elems.empty() )
       {  _elems.push_back( 1 ); _elems.push_back( 2 ); }

    if ( _elems.size() <= pos )
	{
		    int ix = _elems.size();
			int n_2 = _elems[ ix-2 ], 
				n_1 = _elems[ ix-1 ];

			int elem;
			for ( ; ix <= pos; ++ix ){
				    elem = n_2 + 2 * n_1; 
					_elems.push_back( elem );
					n_2 = n_1; n_1 = elem;
			}
	 }
}
   
void Lucas::
gen_elems( int pos ) const
{     
	if ( pos <= 0 || 
		 pos > num_sequence<Lucas>::max_elems() )
		       return;

    if ( _elems.empty() )
       {  _elems.push_back( 1 ); _elems.push_back( 3 ); }

    if ( _elems.size() <= pos )
	{
		    int ix = _elems.size();
			int n_2 = _elems[ ix-2 ], 
				n_1 = _elems[ ix-1 ];

			int elem;
			for ( ; ix <= pos; ++ix ){
				    elem = n_2 +  n_1; 
					_elems.push_back( elem );
					n_2 = n_1; n_1 = elem;
			}
	 }
}    

void Triangular::
gen_elems( int pos ) const
{
	if ( pos <= 0 || 
		 pos > num_sequence<Triangular>::max_elems() )
		       return;

    if ( _elems.size() <= pos )
	{
		int end_pos = pos+1;
		int ix = _elems.size()+1;
		
		for ( ; ix <= end_pos; ++ix )
			  _elems.push_back( ix*(ix+1)/2 );
	}
}

void Square::
gen_elems( int pos ) const
{
	if ( pos <= 0 || 
		 pos > num_sequence<Square>::max_elems() )
		       return;

    if ( _elems.size() <= pos )
	{
		int end_pos = pos + 1;
		int ix = _elems.size()+1;
		for ( ; ix <= end_pos; ++ix )
			  _elems.push_back( ix*ix );
	}
}   
    
void Pentagonal::
gen_elems( int pos ) const
{
	if ( pos <= 0 || 
		 pos > num_sequence<Pentagonal>::max_elems() )
		       return;

    if ( _elems.size() <= pos )
	{
		int end_pos = pos + 1;
		int ix = _elems.size()+1;
		for ( ; ix <= end_pos; ++ix )
			  _elems.push_back( ix*(3*ix-1)/2 );
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品一区二区三区| 国产欧美日韩麻豆91| 久久精品在这里| 亚洲高清免费观看高清完整版在线观看 | 91精品国产综合久久精品app | 精品国产伦一区二区三区免费| 中文字幕国产精品一区二区| 图片区日韩欧美亚洲| av一区二区不卡| 精品久久久久一区二区国产| 亚洲一区在线观看免费观看电影高清| 国产成人午夜视频| 欧美一区二区日韩一区二区| 亚洲国产精品一区二区www在线| 成人综合激情网| 久久蜜臀中文字幕| 久久99国产精品尤物| 欧美日韩国产不卡| 亚洲午夜羞羞片| 在线视频国内自拍亚洲视频| 成人免费在线播放视频| 国产精品1区2区| 日韩精品一区国产麻豆| 蜜臀久久久久久久| 欧美精品三级日韩久久| 亚洲午夜精品一区二区三区他趣| 99热精品一区二区| 国产精品欧美久久久久无广告 | 国产乱人伦偷精品视频免下载| 欧美一级久久久| 日韩专区中文字幕一区二区| 欧美日韩视频在线观看一区二区三区| 亚洲色图19p| 99国产精品一区| 亚洲视频小说图片| 在线精品视频免费播放| 亚洲精品va在线观看| 91精品福利在线| 亚洲制服丝袜av| 精品视频在线视频| 香蕉成人伊视频在线观看| 欧美最新大片在线看| 亚洲国产视频一区| 91精品在线麻豆| 久久99精品国产麻豆婷婷洗澡| 欧美大黄免费观看| 国产精品99久久久久久似苏梦涵| 久久精品一级爱片| 91免费精品国自产拍在线不卡 | 91免费在线看| 亚洲国产美女搞黄色| 欧美日韩国产乱码电影| 麻豆成人免费电影| 国产日韩三级在线| 色88888久久久久久影院野外 | 欧美日韩一区二区三区在线| 亚洲成人自拍网| 26uuu国产电影一区二区| av成人老司机| 免费黄网站欧美| 欧美激情在线一区二区三区| 色老综合老女人久久久| 日本vs亚洲vs韩国一区三区二区 | 欧美日韩亚洲另类| 经典三级一区二区| 亚洲乱码国产乱码精品精可以看 | 成人av网址在线| 一级女性全黄久久生活片免费| 91麻豆精品91久久久久久清纯 | 国产在线不卡一卡二卡三卡四卡| 国产精品美女久久久久久久久久久| 欧美性极品少妇| 国产成人精品一区二区三区四区| 亚洲一区二区三区四区五区中文 | 国产精品69毛片高清亚洲| 夜夜精品浪潮av一区二区三区| 精品久久久久久最新网址| 91一区二区三区在线观看| 精油按摩中文字幕久久| 亚洲一区成人在线| 国产精品麻豆欧美日韩ww| 日韩精品一区二区三区四区视频| 91麻豆视频网站| 国产精品自拍网站| 亚洲成av人片在线观看| 国产精品久久综合| 精品国产一区二区三区不卡 | 亚洲精品视频一区| 精品国产乱码久久久久久久久| 在线观看日韩国产| 成人av在线网| 国产精品77777| 国产在线播放一区| 日韩精品一区第一页| 亚洲欧洲综合另类在线| 亚洲国产高清在线观看视频| 日韩欧美另类在线| 777奇米成人网| 一本大道久久a久久综合| 成人午夜视频在线观看| 狠狠色丁香久久婷婷综| 免费在线观看一区| 日韩激情av在线| 一二三区精品福利视频| 日韩伦理免费电影| 国产精品久久久久一区二区三区| 国产亚洲1区2区3区| 久久亚洲影视婷婷| 精品成人私密视频| 精品免费99久久| 欧美成人三级电影在线| 欧美一区二区三区在线| 91.麻豆视频| 欧美一区二区三区四区视频| 91精品国产乱码| 欧美成人vps| 精品福利一区二区三区免费视频| 日韩欧美国产午夜精品| 欧美变态tickling挠脚心| 欧美一区二区三区在线电影| 日韩视频免费观看高清完整版| 欧美一区二区不卡视频| 欧美成人官网二区| 国产婷婷色一区二区三区四区| 国产亚洲精品中文字幕| 国产精品毛片久久久久久久| 亚洲免费观看高清完整版在线观看 | 久久综合九色综合97婷婷女人| 91精品国产色综合久久久蜜香臀| 777xxx欧美| 久久一区二区三区国产精品| 欧美国产禁国产网站cc| 1区2区3区国产精品| 亚洲国产精品人人做人人爽| 男人的天堂久久精品| 国内外成人在线| k8久久久一区二区三区| 欧美日韩一区二区电影| 日韩欧美激情在线| 国产清纯白嫩初高生在线观看91 | 色综合天天狠狠| 欧美另类久久久品| 精品久久久久一区| 亚洲欧美韩国综合色| 日本中文一区二区三区| 成人免费毛片aaaaa**| 欧美日韩免费不卡视频一区二区三区| 日韩一区二区三区免费观看| 欧美国产欧美综合| 丝袜国产日韩另类美女| 国产精品一区一区| 欧美视频一区在线| 国产亚洲欧美中文| 五月天一区二区| 国产成人精品免费看| 欧美性欧美巨大黑白大战| 日韩免费福利电影在线观看| 国产精品第四页| 免费美女久久99| 日本韩国精品在线| 欧美精品一区二区三区四区| 一区二区三区免费看视频| 国产综合色在线| 欧美日韩三级一区| 国产精品久久久久久久午夜片| 免费成人在线视频观看| 欧美少妇bbb| 亚洲欧洲精品一区二区三区 | 五月天视频一区| 成人午夜激情在线| 精品国产a毛片| 婷婷久久综合九色综合绿巨人| 成人综合在线观看| 欧美本精品男人aⅴ天堂| 亚洲一本大道在线| 色偷偷88欧美精品久久久| 久久蜜桃香蕉精品一区二区三区| 视频一区在线播放| 日本电影亚洲天堂一区| 国产精品免费看片| 国产成人免费在线观看| 精品99一区二区三区| 日日夜夜一区二区| 欧美三级韩国三级日本一级| 亚洲婷婷国产精品电影人久久| 国产精品自在在线| 久久在线观看免费| 久久66热偷产精品| 91精品国产一区二区三区蜜臀| 亚洲在线免费播放| 在线精品观看国产| 一区二区三区美女| 欧美性猛片aaaaaaa做受| 亚洲一二三四区| 欧美亚男人的天堂| 午夜精品福利久久久| 欧美色偷偷大香| 午夜成人免费电影| 日韩一二在线观看| 九九**精品视频免费播放|