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

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

?? buffer.cpp

?? VC數值程序設計的源代碼
?? 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一区二区三区免费野_久草精品视频
秋霞成人午夜伦在线观看| 国产精品18久久久久久久久| 秋霞国产午夜精品免费视频| 国产91精品精华液一区二区三区 | 1024成人网色www| 日本在线不卡视频一二三区| proumb性欧美在线观看| 日韩精品资源二区在线| 一区二区欧美国产| 成人av资源站| 久久亚洲综合av| 日韩电影在线观看电影| 色综合天天综合给合国产| 久久久三级国产网站| 日韩在线卡一卡二| 色婷婷av一区| 国产精品电影院| 国产精品一区二区视频| 日韩一区二区在线播放| 午夜欧美大尺度福利影院在线看| 色婷婷国产精品| 一区二区三区在线免费视频| 国产成人av影院| 久久久久青草大香线综合精品| 视频在线在亚洲| 4438亚洲最大| 日韩精品91亚洲二区在线观看| 欧美日韩国产高清一区| 亚洲一区二区三区四区在线| 色综合色狠狠天天综合色| 综合久久国产九一剧情麻豆| 成人黄色小视频| 日韩国产精品久久| 欧美日韩一卡二卡三卡 | 91福利在线播放| 亚洲欧美日韩中文字幕一区二区三区| 高潮精品一区videoshd| 中文字幕欧美区| 99re这里只有精品视频首页| 1区2区3区精品视频| 一本色道久久综合精品竹菊| 日韩理论片一区二区| 91看片淫黄大片一级| 亚洲综合免费观看高清在线观看 | 国产精品 欧美精品| 久久久噜噜噜久久人人看| 国产精品综合视频| 国产精品美女www爽爽爽| 波多野结衣中文字幕一区二区三区 | 精品久久人人做人人爱| 国内精品自线一区二区三区视频| 久久久国产精华| 99精品欧美一区| 图片区日韩欧美亚洲| 精品日本一线二线三线不卡| 国产.欧美.日韩| 一区二区三区视频在线看| 欧美日韩国产影片| 国产一区二区免费在线| 亚洲精品亚洲人成人网| 5566中文字幕一区二区电影| 国产一区二区在线观看免费| 成人免费一区二区三区视频 | 久久久精品免费网站| 日韩一卡二卡三卡| 国产成人a级片| 亚洲成人在线观看视频| www久久久久| 一本在线高清不卡dvd| 美女视频网站久久| 亚洲精品中文字幕在线观看| 欧美白人最猛性xxxxx69交| 99re成人精品视频| 麻豆国产91在线播放| 亚洲激情综合网| 精品99久久久久久| 欧美日产国产精品| 91麻豆国产福利精品| 国产乱淫av一区二区三区| 亚洲网友自拍偷拍| 最好看的中文字幕久久| 久久综合久久综合亚洲| 欧美视频你懂的| 成人app网站| 国产一区二区三区在线观看免费 | 精品国产一区久久| 在线观看www91| 成人免费毛片嘿嘿连载视频| 美女一区二区三区| 香蕉加勒比综合久久| 亚洲女同ⅹxx女同tv| 久久久五月婷婷| 日韩欧美资源站| 欧美美女bb生活片| 色悠悠久久综合| 成人av网站大全| 国产69精品一区二区亚洲孕妇| 久久综合综合久久综合| 一区二区三区欧美日| 日韩毛片在线免费观看| 国产精品视频一区二区三区不卡| 精品成人在线观看| 精品区一区二区| 久久视频一区二区| 26uuuu精品一区二区| 精品久久国产字幕高潮| 日韩午夜小视频| 欧美一区二区视频网站| 欧美日韩一级片网站| 欧美亚洲国产一区二区三区va| 色屁屁一区二区| 欧美伊人久久久久久午夜久久久久| 不卡一区二区三区四区| 99国内精品久久| 91视频国产观看| 一本久久精品一区二区| 久久久久久久久免费| 2021国产精品久久精品| 欧美精品一区二区高清在线观看| 精品国产免费人成电影在线观看四季 | 欧美日韩一区在线| 欧美日韩一区二区欧美激情| 7799精品视频| 日韩欧美视频在线| 久久久久久久久久电影| 中文字幕av资源一区| 中文字幕在线观看一区二区| 亚洲欧洲av一区二区三区久久| 亚洲欧美一区二区久久| 亚洲不卡一区二区三区| 三级久久三级久久| 国产一区二区三区免费看| 国产成人精品1024| 91福利视频久久久久| 91麻豆精品国产91久久久资源速度 | 国产精品网站在线观看| 国产精品成人网| 亚洲18色成人| 国产毛片精品视频| 色综合婷婷久久| 91精品国产综合久久久久久久 | 国产成人精品亚洲日本在线桃色| 国产精品亚洲人在线观看| 99精品视频在线观看免费| 欧美日韩成人在线一区| 久久久不卡网国产精品一区| 成人免费一区二区三区视频 | 亚洲欧美偷拍三级| 蜜臀av一区二区| 成人动漫精品一区二区| 91 com成人网| 中文字幕在线不卡视频| 奇米影视在线99精品| av一二三不卡影片| 91精品一区二区三区在线观看| 国产精品婷婷午夜在线观看| 亚洲一区精品在线| 国产成人免费视频一区| 欧美日韩在线播| 亚洲欧美在线视频| 国产在线视频一区二区| 欧美日韩一区二区欧美激情 | 午夜激情一区二区三区| 国产99精品国产| 宅男噜噜噜66一区二区66| 国产精品免费看片| 日韩中文字幕91| 一本色道**综合亚洲精品蜜桃冫| 欧美精品一区二区三区四区| 亚洲不卡一区二区三区| 99麻豆久久久国产精品免费| 日韩视频123| 亚洲18色成人| 欧美又粗又大又爽| 综合电影一区二区三区| 韩国一区二区视频| 欧美一区二视频| 亚洲高清一区二区三区| 欧美一区二区三区婷婷月色| 国产精品毛片大码女人| 国产精品资源在线观看| 欧美一区二区性放荡片| 亚洲成人av福利| 91精品福利在线| 亚洲欧美一区二区三区极速播放 | 精品一区二区三区免费播放| 欧美少妇一区二区| 亚洲九九爱视频| 91丨porny丨国产入口| 国产精品嫩草影院av蜜臀| 国产成人午夜片在线观看高清观看| 欧美一区二区三区免费观看视频| 亚洲香蕉伊在人在线观| 色诱亚洲精品久久久久久| 亚洲精品视频一区| 色偷偷一区二区三区| 夜夜揉揉日日人人青青一国产精品 | 一区二区三区免费网站| 99久久综合色| 亚洲欧美日本韩国|