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

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

?? buffer.cpp

?? c語言編寫數學常用算法
?? CPP
字號:
#include <stdio.h>
#include <string.h>
#include <fstream.h>

// 功能:實現buffer.h中的各個緩沖類的函數

#include "buffer.h"
#include "cbuffer.h"

DOUBLE defaulterr = 1e-8; 	// 缺省的誤差調整值
int doadjust = 1;		// 決定數據是否根據誤差值自動向整數靠擾,
							// 其實是向小數點后三位靠擾

/* 下面的六個指針分別初始化指向產生六個緩沖區長度為空的六個
	緩沖區,其中兩個實數緩沖區,兩個長整數緩沖區,兩個復數緩沖區
  其中實數,長整數和復數這三種數據類型的每一種都有磁盤和內存兩種
  緩沖區。如果數據較小時可以存放在內存中,而數據量很大時則存放在
  臨時文件構成的磁盤緩沖區中。這六個空緩沖區并不真正用來存放數據,
  而是用來產生出新的與自己一樣的緩沖區,因為它們都是抽象類buffer的
  子類,所以都將被settomemory函數或者settodisk函數賦給三個buffer類的
  指針,使得getnewbuffer,getnewcbuffer和getnewlbuffer三個函數能夠從這些
  緩沖區中用抽象類函數產生同樣類型的緩沖區。
  總的想法是,在以后編寫的計算各種矩陣或者行列式,或者其它的大量
  數據的運算時,只要調用一次settomemroy或者settodisk函數,那么用戶
  不必改寫一行代碼,就可以照算不誤,而存儲媒體已經改變。
*/
static membuffer *memorybuffer = new membuffer; // 實數內存緩沖區指針
static diskbuffer *diskfilebuffer = new diskbuffer; // 實數磁盤緩沖區指針
static lmembuffer *memorylbuffer = new lmembuffer; // 長整數內存緩沖區指針
static ldiskbuffer *diskfilelbuffer = new ldiskbuffer; // 長整數磁盤緩沖區指針
static memcbuffer *memorycbuffer = new memcbuffer; // 復數內存緩沖區指針
static diskcbuffer *diskfilecbuffer = new diskcbuffer; // 復數磁盤緩沖區指針


/* 以下三個缺省緩沖區指針為全局變量,用戶可以定義自己的緩沖區
	類,并在產生靜態實例變量后將其指針賦予它們 */

buffer *defbuffer = memorybuffer; // 缺省實數緩沖區指針
lbuffer *deflbuffer = memorylbuffer; // 缺省長整數緩沖區指針
cbuffer *defcbuffer = memorycbuffer; // 缺省復數緩沖區指針


/* 產生一個新的容量為n個實數的實數緩沖區,返回此緩沖區指針,
	緩沖區的類型與defbuffer指向的變量的子類類型相同 */
buffer * getnewbuffer(size_t n){
	return defbuffer->newbuf(n);
}

/* 產生一個新的容量為n個長整數的長整數緩沖區,返回此緩沖區指針,
	緩沖區的類型與deflbuffer指向的變量的子類類型相同 */
lbuffer * getnewlbuffer(size_t n){
	return deflbuffer->newbuf(n);
}

/* 產生一個新的容量為n個復數的復數緩沖區,返回此緩沖區指針,
	緩沖區的類型與defcbuffer指向的變量的子類類型相同 */
cbuffer * getnewcbuffer(size_t n){
	return defcbuffer->newbuf(n);
}

// 將各實數,長整數和復數的缺省的緩沖區指針指向相應的磁盤緩沖區指針
void settodisk()
{
	defbuffer = diskfilebuffer;
	deflbuffer = diskfilelbuffer;
	defcbuffer = diskfilecbuffer;
}

// 將各實數,長整數和復數的缺省的緩沖區指針指向相應的內存緩沖區指針
void settomemory()
{
	defbuffer = memorybuffer;
	deflbuffer = memorylbuffer;
	defcbuffer = memorycbuffer;
}

ostream& operator<<(ostream& o, buffer& b)
{
	size_t maxitem = 5;
	for(size_t i=0; i<b.len(); i++) {
		o << b[i] << '\t';
		if(((i+1) % maxitem)==0)
			o << endl;
	}
	o << endl;
	return o;
}


// 將實數緩沖區的第n個實數的值設為d,并返回一個實數緩沖區的
// 指針,此指針一般就是指向自己,而在一個緩沖區的引用數多于一個時
// 此函數將先克隆出一個新的緩沖區,此新的緩沖區的引用數為1,并對此
// 新的緩沖區的第n個實數的值設為d,然后返加新緩沖區的指針
buffer* buffer::set(size_t n, DOUBLE d)
{
	// 如調整標志設置,則調整
	if(doadjust) adjust(d);
	if(refnum == 1) {	// 如果引用數為1,則將第n個實數的值設為d,并返回自己
			// 的指針
		retrieve(n) = d;
		return this;
	}
	refnum --;	// 引用數大于1,因此將本緩沖區的引用數減1
	buffer * b;
	b = clone();	// 克隆一個內容同自己一樣的新緩沖區
	(b->retrieve(n)) = d; // 將新緩沖區的第n個實數的值設為d
	return b;	// 返回新緩沖區的指針
}

buffer* membuffer::clone() // 克隆一個內容和自己一樣的實數內存緩沖區,并返回其指針
{
	buffer* b;
	b = new membuffer(length);	// 建立一個新的實數內存緩沖區,尺寸和自己的一樣
	if(length > 0)	// 如果自己有內容,將全部拷貝到新產生的緩沖區中
		for(size_t i=0; i<length; i++)
			(b->retrieve(i)) = (*this)[i];
	return b;
}

// 實數磁盤緩沖區構造函數
diskbuffer::diskbuffer(size_t lth):buffer(),length(lth),n(0)
{
	tempfp = tmpfile();	// 打開一新的臨時文件,指針賦給tempfp
}

// 實數磁盤緩沖區的析構函數
diskbuffer::~diskbuffer()
{
	fclose(tempfp);	// 關閉臨時文件
}

void diskbuffer::alloc(size_t num) // 將磁盤緩沖區重新定為尺寸為num
{
	length = num;
	if(!tempfp)	 // 如果臨時文件尚未打開,則打開臨時文件
		tempfp = tmpfile();
	n = 0;	// 當前緩沖區指針設在開始,就是0處
}

void diskbuffer::release() // 釋放磁盤緩沖區
{
	fclose(tempfp);	// 關閉臨時文件
	buf = 0.0;
	length = 0;
}

DOUBLE& diskbuffer::retrieve(size_t i) // 返回實數磁盤緩沖區的第i個實數
{
	long off;
	off = n*sizeof(DOUBLE); // 計算出當前指針n對應的文件的偏移量
	fseek(tempfp, off, SEEK_SET); // 移動文件指針到給定的偏移量處
	fwrite(&buf, sizeof(DOUBLE), 1, tempfp); // 將當前的buf中值寫到文件中
	off = i*sizeof(DOUBLE); // 計算第i個實數在文件的什么位置
	fseek(tempfp, off, SEEK_SET); // 移動文件指針到給定的偏移量處
	fread(&buf, sizeof(DOUBLE), 1, tempfp); // 讀回所需的實數值到buf中
	n = i;	// 并將n改為i
	return buf; // 返回讀出的實數的引用
}

buffer* diskbuffer::clone() // 克隆一個新的內容與自己一樣的實數磁盤緩沖區
{
	buffer* b;
	b = new diskbuffer(length); // 定位產生一個與自己長度一樣的新緩沖區
	if(length > 0)	// 如果長度大于0,則自己的內容拷貝到新緩沖區
		for(size_t i=0; i<length; i++)
			(b->retrieve(i)) = (*this)[i];
	return b; // 返回新緩沖區的指針
}


// 將第n個長整數的值設為v,如果緩沖區的引用數大于1,
// 則會先克隆出新的緩沖區,然后再進行操作,并返回新緩沖區的指針
lbuffer* lbuffer::set(size_t n, long v)
{
	if(refnum == 1) { //  引用數為1
		retrieve(n) = v; // 將第n個長整數的值設為v
		return this;	// 返回自己
	}
	refnum --;		// 引用數大于1,引用數減1
	lbuffer * b;
	b = clone();	// 克隆出新的內容一樣的長整數緩沖區
	(b->retrieve(n)) = v; // 將新緩沖區的第n個長整數值設為v
	return b;	// 返回新緩沖區的指針
}

ostream& operator<<(ostream& o, lbuffer& b)
{
	size_t maxitem = 5;
	for(size_t i=0; i<b.len(); i++) {
		o << b[i] << '\t';
		if(((i+1) % maxitem)==0)
			o << endl;
	}
	o << endl;
	return o;
}

lbuffer* lmembuffer::clone() // 克隆一個內容一新的長整數內存緩存區
{
	lbuffer* b;
	b = new lmembuffer(length);	// 產生長度與自己一樣的長整數緩存區
	if(length > 0)	// 如果長度大于0,則將自己的內容拷貝過去
		for(size_t i=0; i<length; i++)
			(b->retrieve(i)) = (*this)[i];
	return b;	// 返回新緩存區的指針
}

// 長整數磁盤緩存區的構造函數
ldiskbuffer::ldiskbuffer(size_t lth):lbuffer(),length(lth),n(0)
{
	tempfp = tmpfile();	// 打開臨時文件
}

// 長整數磁盤緩存區的析構函靈敏
ldiskbuffer::~ldiskbuffer()
{
	fclose(tempfp);	// 關閉臨時文件
}

// 將長度定改為num
void ldiskbuffer::alloc(size_t num)
{
	length = num;
	if(!tempfp) // 如臨時文件尚未打開,則打開
		tempfp = tmpfile();
	n = 0;
}

// 長整數磁盤緩存區釋放
void ldiskbuffer::release()
{
	fclose(tempfp);	// 關閉臨時文件
	buf = 0;
	length = 0;
}

// 檢索第i個值的引用
long& ldiskbuffer::retrieve(size_t i)
{
	long off;
	off = n*sizeof(long); // 先將當前的內容保存
	fseek(tempfp, off, SEEK_SET);
	fwrite(&buf, sizeof(long), 1, tempfp);
	off = i*sizeof(long);	// 再取出第i個長整數到buf中
	fseek(tempfp, off, SEEK_SET);
	fread(&buf, sizeof(long), 1, tempfp);
	n = i;
	return buf;
}

// 克隆一個和內容和自己一樣的長整數磁盤緩存區
lbuffer* ldiskbuffer::clone()
{
	lbuffer* b;
	b = new ldiskbuffer(length); // 產生長度和自己一樣的緩存區
	if(length > 0)	// 如果自己內容不為空,拷貝內容到新的緩存區
		for(size_t i=0; i<length; i++)
			(b->retrieve(i)) = (*this)[i];
	return b;
}

DOUBLE adjust(DOUBLE & a) // 將實數調整為最靠近小數點后二位的實數
// 準則:如果一個實數距某個二位小數小于十的負八次冪,則調整為這個小數
// 否則不變
{
	DOUBLE b = floor(a*100.0+0.5)/100.0; // b是四舍五入到小數點后二位
	if(fabs(b-a)<defaulterr) // 如果舍入誤差極小,則拋棄
		a = b;
	return a;
}

char * throwmessage(int l, char * f, char * c)
{
	static char a[100];
	sprintf(a,"file:%s,line:%d\nmessage:%s\n",f,l,c);
	return a;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
粉嫩av亚洲一区二区图片| 麻豆一区二区三区| 久久综合九色综合97_久久久| 日本国产一区二区| 成人在线综合网站| 国产精品一区二区三区四区| 久久国产精品第一页| 亚洲国产一二三| 夜夜精品视频一区二区| 一级精品视频在线观看宜春院| 中文字幕一区二| 亚洲精品视频免费观看| 亚洲欧美激情插 | 久久精品99久久久| 美美哒免费高清在线观看视频一区二区 | 色成年激情久久综合| 美女在线一区二区| 久久国产精品免费| 国产精品综合二区| 成人一区在线观看| 色综合中文字幕国产| www.66久久| 欧美亚洲一区二区在线| 在线电影院国产精品| 日韩免费观看高清完整版| 精品福利在线导航| 国产精品久久久久久久久免费樱桃| 国产精品视频免费| 亚洲人成精品久久久久久 | 91搞黄在线观看| 91麻豆精品91久久久久同性| 欧美一区二区三区啪啪| 久久久另类综合| 有坂深雪av一区二区精品| 亚洲成av人在线观看| 国产一区在线观看视频| 91免费看视频| 日韩视频免费观看高清在线视频| 久久久国产精品麻豆| 亚洲一区二区三区中文字幕 | 亚洲久本草在线中文字幕| 午夜视频一区二区| 国产馆精品极品| 99视频在线精品| 日韩欧美一级在线播放| 国产亚洲一区字幕| 一区二区三区高清在线| 奇米精品一区二区三区四区| 国产成a人无v码亚洲福利| 欧美久久久久久久久中文字幕| 久久久久久久久岛国免费| 亚洲风情在线资源站| 成人在线一区二区三区| 欧美一区二区三区思思人| 最新不卡av在线| 国产一区二区三区日韩| 884aa四虎影成人精品一区| 国产精品国产三级国产aⅴ中文 | 狠狠网亚洲精品| 欧美精选一区二区| 亚洲蜜臀av乱码久久精品| 激情丁香综合五月| 欧美日韩视频第一区| 亚洲三级免费观看| 岛国精品一区二区| 日韩一区和二区| 亚洲va欧美va人人爽| 日本大香伊一区二区三区| 国产精品人人做人人爽人人添| 久久福利视频一区二区| 欧美精品aⅴ在线视频| 一区二区国产视频| 色噜噜狠狠色综合中国| 中文字幕在线不卡一区二区三区| 国内外成人在线| www国产成人免费观看视频 深夜成人网| 亚洲一区二区三区精品在线| 91美女片黄在线观看| 国产精品久久久久久久午夜片 | 精品少妇一区二区三区| 三级成人在线视频| 欧美精品v日韩精品v韩国精品v| 亚洲第一福利一区| 欧美久久久久久久久久| 日韩国产精品久久久| 欧美一区二区网站| 美国av一区二区| 精品久久久久久综合日本欧美| 亚洲二区在线视频| 7777精品伊人久久久大香线蕉超级流畅| 亚洲综合久久av| 在线中文字幕一区| 亚洲一区二区三区视频在线 | 91精品国产色综合久久| 美日韩一区二区三区| 精品999在线播放| 国产九九视频一区二区三区| 精品美女一区二区三区| 国产黄色精品网站| 亚洲天堂免费在线观看视频| 91国产免费观看| 免费成人在线视频观看| 久久综合久久99| 不卡的看片网站| 亚洲成人午夜影院| 欧美精品久久一区二区三区| 久久99精品国产91久久来源| 精品久久久久久久久久久久久久久久久 | 波多野结衣中文一区| 中文av一区特黄| 91精品福利在线| 麻豆91精品91久久久的内涵| 久久美女高清视频| 91麻豆自制传媒国产之光| 五月天久久比比资源色| 日韩女同互慰一区二区| 成人一区二区三区在线观看| 综合久久久久久| 91精品国产综合久久小美女| 高清av一区二区| 视频一区二区国产| 国产日韩av一区| 欧美日韩精品三区| 国产福利一区二区三区视频在线 | 国产精品久久久久精k8| 91精品久久久久久久久99蜜臂| 国产精品1区2区3区在线观看| 亚洲卡通动漫在线| 久久精品日产第一区二区三区高清版| 成人a级免费电影| 日本sm残虐另类| 一区二区在线看| 久久九九影视网| 在线不卡中文字幕播放| 99精品一区二区三区| 久久99深爱久久99精品| 亚洲一区在线观看网站| 国产欧美一区二区精品仙草咪| 欧美麻豆精品久久久久久| 99久久精品国产观看| 国产一区不卡视频| 免费人成在线不卡| 亚洲国产aⅴ成人精品无吗| 亚洲视频一二三| 欧美国产精品一区二区三区| 精品理论电影在线| 在线精品视频免费播放| av在线不卡电影| 成人app软件下载大全免费| 蜜桃免费网站一区二区三区| 日韩激情av在线| 亚洲高清免费观看高清完整版在线观看| 国产精品区一区二区三区| 欧美xxxx老人做受| 欧美一区二区三区色| 337p亚洲精品色噜噜狠狠| 欧美日韩免费观看一区二区三区| 91国内精品野花午夜精品| 色婷婷国产精品综合在线观看| va亚洲va日韩不卡在线观看| 国产精品亚洲成人| 国产91精品一区二区麻豆网站| 国产酒店精品激情| 国产a级毛片一区| 成人小视频在线| 99久久99久久精品国产片果冻 | 亚洲免费看黄网站| 亚洲视频你懂的| 一区二区日韩av| 夜夜嗨av一区二区三区网页| 亚洲一区二区偷拍精品| 午夜精品国产更新| 久久精品99久久久| 国产一区在线精品| 成人性生交大片免费看视频在线 | 日韩一区在线看| 一区二区三区日韩欧美| 亚洲成人免费看| 精品无人码麻豆乱码1区2区 | 在线一区二区三区做爰视频网站| 成人永久免费视频| 91久久精品一区二区二区| 欧美久久婷婷综合色| 精品处破学生在线二十三| 国产精品美女久久久久aⅴ| 亚洲欧美精品午睡沙发| 视频一区中文字幕国产| 国产麻豆欧美日韩一区| 91小视频免费看| 欧美乱熟臀69xxxxxx| 久久久久99精品国产片| 一区二区三区在线观看视频| 免费看日韩精品| thepron国产精品| 欧美人狂配大交3d怪物一区| 欧美精品一区二区三区高清aⅴ | 一区二区成人在线视频| 美女视频网站黄色亚洲| 99久久免费视频.com| 欧美大片一区二区三区|