亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
欧美日韩成人在线| 亚洲激情一二三区| 亚洲免费三区一区二区| 日本怡春院一区二区| www.久久久久久久久| 日韩欧美国产电影| 亚洲18影院在线观看| 99久久精品99国产精品| 精品处破学生在线二十三| 亚洲成av人片一区二区三区| av电影在线观看一区| 精品国产三级a在线观看| 天天影视色香欲综合网老头| av成人免费在线| 国产清纯白嫩初高生在线观看91 | 日本不卡视频一二三区| 成人免费高清在线观看| 日韩免费福利电影在线观看| 日本午夜一区二区| 欧美日韩在线播放三区四区| 综合自拍亚洲综合图不卡区| 成人av在线看| 日韩福利电影在线观看| 日韩一区二区三区在线| 一区二区三区四区在线播放| 成人综合婷婷国产精品久久| 欧美一区二区三级| 天天综合网 天天综合色| 91蜜桃免费观看视频| 国产精品电影一区二区| 国产精品一区二区免费不卡| 日韩一区二区三区免费看| 午夜伊人狠狠久久| 在线不卡中文字幕播放| 天天色天天爱天天射综合| 欧美日韩一区视频| 日本视频中文字幕一区二区三区| 欧美性猛片xxxx免费看久爱| 亚洲自拍偷拍图区| 欧美另类高清zo欧美| 亚洲精品大片www| 欧美在线不卡视频| 天天综合天天做天天综合| 欧美二区在线观看| 久久国产精品72免费观看| 久久久久久久电影| 波波电影院一区二区三区| 亚洲欧美激情在线| 色综合天天在线| 亚洲国产日韩综合久久精品| 91精品国产aⅴ一区二区| 精品一区中文字幕| 欧美激情一区在线| 欧美性猛交xxxxxx富婆| 日本午夜精品一区二区三区电影| 久久午夜电影网| 99久久精品一区| 五月天中文字幕一区二区| 精品美女被调教视频大全网站| 国产精品一区二区无线| 亚洲欧美另类小说视频| 欧美一级电影网站| 国产精品影音先锋| 亚洲另类中文字| 精品国产在天天线2019| 色偷偷久久人人79超碰人人澡| 亚洲成人精品一区| 亚洲国产精品二十页| 欧美精品九九99久久| 国产福利不卡视频| 丝袜亚洲另类丝袜在线| 国产精品色一区二区三区| 欧美日韩电影在线| 成人开心网精品视频| 日韩精品乱码av一区二区| 国产精品久久久久一区二区三区 | 69堂亚洲精品首页| 国产成人午夜精品影院观看视频 | 激情都市一区二区| 一区二区三区日韩欧美| 久久久另类综合| 欧美日韩一区二区在线观看| 福利91精品一区二区三区| 五月天中文字幕一区二区| 亚洲靠逼com| 视频在线观看91| 中文在线一区二区| 欧美乱熟臀69xxxxxx| 成人美女视频在线观看| 青椒成人免费视频| 亚洲激情成人在线| 国产精品久久久久久妇女6080| 日韩一二三区视频| 欧美日韩黄色影视| 色av成人天堂桃色av| 成人午夜看片网址| 激情久久久久久久久久久久久久久久| 亚洲伊人伊色伊影伊综合网| 国产欧美一区二区精品性| 日韩精品一区二区在线| 欧美久久婷婷综合色| 欧美午夜电影网| 一本高清dvd不卡在线观看| 成人免费视频app| 国产精品一区二区不卡| 久久99久国产精品黄毛片色诱| www.欧美亚洲| 成人不卡免费av| 大桥未久av一区二区三区中文| 国产一区二区久久| 国产在线视视频有精品| 九色综合狠狠综合久久| 麻豆成人久久精品二区三区红| 天天操天天综合网| 日韩制服丝袜先锋影音| 奇米在线7777在线精品 | 精品久久久久久久久久久久久久久久久| 日本精品一区二区三区高清| 色悠悠久久综合| 色综合久久久久久久久| 欧洲av一区二区嗯嗯嗯啊| 色天使久久综合网天天| 欧美视频一二三区| 欧美日韩一区二区欧美激情| 欧美另类高清zo欧美| 717成人午夜免费福利电影| 欧美一级二级三级蜜桃| 精品国产露脸精彩对白| 国产欧美一区二区在线观看| 国产精品久线在线观看| 亚洲免费在线视频一区 二区| 亚洲自拍都市欧美小说| 日韩高清一区二区| 精品一区精品二区高清| 懂色av一区二区三区蜜臀| av不卡免费在线观看| 色婷婷国产精品综合在线观看| 欧美女孩性生活视频| 精品成人佐山爱一区二区| 日本一区二区在线不卡| 夜夜嗨av一区二区三区中文字幕 | 欧美在线视频不卡| 欧美男同性恋视频网站| 精品国产乱码久久久久久久久| 国产清纯白嫩初高生在线观看91| 国产精品久久久久桃色tv| 亚洲国产aⅴ天堂久久| 另类调教123区| 成人激情动漫在线观看| 欧美日精品一区视频| 精品国产一区二区在线观看| 国产精品久久久久婷婷| 日韩电影一区二区三区| 成人黄页在线观看| 欧美日韩精品一区二区三区四区| 久久综合中文字幕| 一区二区三区色| 国产精品一二一区| 欧美男女性生活在线直播观看| 26uuu精品一区二区在线观看| 亚洲靠逼com| 狠狠色丁香九九婷婷综合五月| 99精品视频一区二区三区| 91精品国产综合久久福利| 日韩一区欧美一区| 久久国产精品色| 欧美性猛交xxxxxxxx| 国产精品剧情在线亚洲| 久久99精品网久久| 欧美日韩国产影片| 一区在线观看视频| 国产一区二区主播在线| 欧美久久高跟鞋激| 一区二区三区中文字幕精品精品| 国产一区视频在线看| 在线观看91av| 亚洲一区二区三区激情| 99热99精品| 久久精品人人爽人人爽| 青青草国产精品亚洲专区无| 一本一道久久a久久精品 | 久久免费午夜影院| 日本 国产 欧美色综合| 欧美视频一区二区| 国产高清一区日本| 2023国产精品| 久久99精品网久久| 欧美刺激午夜性久久久久久久| 一区二区免费视频| 色噜噜久久综合| 日韩理论片网站| 99久久精品费精品国产一区二区| 国产日韩一级二级三级| 国产一区二区三区不卡在线观看| 欧美不卡视频一区| 老司机精品视频导航| 337p亚洲精品色噜噜狠狠| 日本伊人精品一区二区三区观看方式| 欧美体内she精高潮| 亚洲激情图片小说视频|