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

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

?? matrix.h

?? 具體實現(xiàn)了c++矩陣運算的類庫
?? H
字號:
#ifndef MATRIX_H
#define MATRIX_H
/*
* @Author:  xuyong;
* mail: xyzw557@sohu.com
*/
#include <iostream>
using namespace std;
namespace _salt
{
	template <class T>
		class matrix{
		public :
			matrix(int row,int colum);
			matrix(const matrix& omatrix);
            ~matrix();
			friend istream& operator >> (istream& ins, matrix& omatrix);
		    friend ostream& operator << (ostream& outs,const matrix& omatrix);
			friend matrix operator+ (const matrix& matrix1,const matrix& matrix2);
			friend matrix operator- (const matrix& matrix1,const matrix& matrix2);
			friend matrix operator* (const matrix& matrix1,const matrix& matrix2);
			//friend matrix operator= ( const matrix& matrix2);
			friend int symbol(int m,int n);
			T get(int i,int j);
			void set(int i,int j,T elem);
			matrix mrest(int i,int j); 
            T hls();
            matrix trans();
			matrix adjoint();// adjoint matrix;
			matrix inverse_matrix();
		private:
			int mrow,mcolum;
			T **p;
	};
	template <class T>
		matrix<T>::matrix(int row,int colum)//create a matrix by given row and colum;
	{
		int i;
		mcolum=colum;
		mrow=row;
		p=new T* [row];
		for(i=0;i<row;i++)
           p[i]=new T[colum];
	}
	template <class T>
		matrix<T>::matrix(const matrix<T>& omatrix)//create a matrix by copying another matrix;
	{
		int i,j;
		mrow=omatrix.mrow;
		mcolum=omatrix.mcolum;
		p=new T* [mrow];
		for(i=0;i<mrow;i++)
			p[i]=new T[mcolum];
		for(i=0;i<mrow;i++)
			for(j=0;j<mcolum;j++)
				p[i][j]=omatrix.p[i][j];
	}
	template <class T>
		matrix<T>::~matrix()//destroy the matrix when the program exit;
	{
		int i;
		for(i=0;i<mrow;i++)
			delete [] p[i];
	}
	template <class T>
		T matrix<T>::get(int i,int j)//get element in matrix by given its row and colum;
	{
		try{
			if(i<0||i>mrow||j<0||j>mcolum) throw 0;
			return p[i][j];
		}
		catch(int n){
			cout<<"i,j are not reasonable!"<<endl;
		}
	}
	template <class T>
		void matrix<T>::set(int i,int j, T elem)//set element whose row and colum is given  in matrix 
	{
		try{
			if(i<0||i>mrow||j<0||j>mcolum) throw 0;
			p[i][j]=elem;
		}
		catch(int n){
			cout<<"i,j are not reasonable!"<<endl;
		}
	}
	/*template <class T>
		matrix<T> operator=(const matrix<T>& omatrix)
	{
		int i,j;
		mrow=omatrix.mrow;
		mcolum=omatrix.mcolum;
		p=new T* [mrow];
		for(i=0;i<mrow;i++)
			p[i]=new T[mcolum];
		for(i=0;i<mrow;i++)
			for(j=0;j<mcolum;j++)
				p[i][j]=omatrix.p[i][j];
		return *this;
	}*/

	template <class T>
		matrix<T> operator+(const matrix<T>& matrix1,const matrix<T>& matrix2)
	{
		//two matrixes add when they are resemble;
		try{
		    int i,j,c,r;
		    c=matrix1.mrow; r=matrix1.mcolum;
	     	matrix<T> temp(c,r);
			if(matrix1.mrow!=matrix2.mrow||matrix1.mcolum!=matrix2.mcolum) throw 0;
		    for(i=0;i<c;i++)
			    for(j=0;j<r;j++)
				   temp.p[i][j]=matrix1.p[i][j]+matrix2.p[i][j];
			return temp;
		}
		catch(int n){
			cout<<"Matrix cannot match!"<<endl;
		}
	}
	template <class T>
		matrix<T> operator-(const matrix<T>& matrix1,const matrix<T>& matrix2)
	{
		//two matrix minus ;
		try{
		    int i,j,c,r;
		    c=matrix1.mrow; r=matrix1.mcolum;
	     	matrix<T> temp(c,r);
			if(matrix1.mcolum!=matrix2.mcolum||matrix1.mrow!=matrix2.mrow) throw 0;
		    for(i=0;i<c;i++)
			    for(j=0;j<r;j++)
				   temp.p[i][j]=matrix1.p[i][j]-matrix2.p[i][j];
			return temp;
		}
		catch(int n){
			cout<<"Matrix cannot match!"<<endl;
		}
	}				
	template <class T>
		matrix<T> operator*(const matrix<T>& matrix1,const matrix<T>& matrix2)
	{
		//two matrixes multiple;
		try{
		    int i,j,k,c,r;
		    c=matrix1.mrow; r=matrix2.mcolum;
	     	matrix<T> temp(c,r);
			if(matrix1.mcolum!=matrix2.mrow) throw 0;
		    for(i=0;i<c;i++)
			    for(j=0;j<r;j++)
					for(k=0;k<matrix1.mcolum;k++){
						if(k==0){
							temp.p[i][j]=matrix1.p[i][0]*matrix2.p[0][j];
							continue;
						}
					   temp.p[i][j]+=matrix1.p[i][k]*matrix2.p[k][j];
					}
			return temp;
		}
		catch(int n){
			cout<<"Matrix cannot match!"<<endl;
		}
	}	

	template <class T>
		istream& operator>>(istream& ins,matrix<T>& mmatrix)
	{
		//reload opretator >> for input elements to matrix easily;
		int i,j;
		for(i=0;i<mmatrix.mrow;i++)
		{
			for(j=0;j<mmatrix.mcolum;j++)
				ins>>mmatrix.p[i][j];
		}

		return ins;
	}
	template <class T>
		ostream& operator<<(ostream& outs,const matrix<T>& mmatrix)
	{
		//reload operator << for output matrix;
		int i,j;
		for(i=0;i<mmatrix.mrow;i++)
			for(j=0;j<mmatrix.mcolum;j++){
				if(j%mmatrix.mcolum==0) outs<<endl;
				outs<<mmatrix.p[i][j]<<"    ";
			}
			outs<<"\n";
			return outs;
	}

	template<class T>
		T matrix<T>::hls()
	{
		//the determinant of matrix;
		int i;
		T val;
		try{
			if(mcolum!=mrow) throw 0;
			if(mrow==1) return p[0][0];
			for(i=0;i<mrow;i++)
			{
				matrix<T> temp1(mrest(0,i));
				if(i==0) {
					
					val=temp1.hls();
					val*=p[0][i];
				}
				else val+=symbol(0,i)*p[0][i]*temp1.hls();
			}
			return val;
		}
		catch(int n){
			cout<<"Matrix cannot match!"<<endl;
			exit(1);
		}
	}
	int symbol(int m,int n)
	{// get value of (-1)^(m+n ) ;
		int val,i;
		val=1;
		for(i=0;i<m+n;i++)
			val*=-1;
		return val;
	}
	template <class T>
		matrix<T> matrix<T>::mrest(int i,int j)
	{  //cofactor of determinant;
		int r,s,k,t;
		matrix<T> temp(mrow-1,mcolum-1);
		for(k=0, r=0;r<mrow;r++)
		{
			if(r==i) continue;
			for(t=0,s=0;s<mcolum;s++)
			{
				if(s==j) continue;
				temp.p[k][t]=p[r][s];
				t++;
			}
			k++;
		}
		return temp;
	}
	template <class T>
		matrix<T> matrix<T>::trans()
	{
		//transpose matrix;
		int i,j;
		matrix<T> temp(mcolum,mrow);
		for(i=0;i<mrow;i++)
		{
			for(j=0;j<mcolum;j++)
				temp.p[j][i]=p[i][j];
		}
		return temp;
	}
		template <class T>
		matrix<T> matrix<T>::adjoint()
	{
		//adjoint matrix;
			int i,j;
			T det;
			matrix<T> temp(mcolum,mrow);
			try{
				if(mcolum!=mrow) throw 0;
				for(i=0;i<mrow;i++)
					for(j=0;j<mcolum;j++)
						temp.p[i][j]=symbol(i,j)*mrest(i,j).hls();
				return temp.trans();
			}
			catch(int n){
				cout<<"Matrix cannot match!"<<endl;
				exit(1);
			}
	}
		template <class T>
		matrix<T> matrix<T>::inverse_matrix()
	{
			int i,j;
			T det;
			det=hls();
			matrix<T> temp(mcolum,mrow);
			try{
				if (det==0) throw 0;
				for (i=0;i<mrow;i++)
					for(j=0;j<mcolum;j++)
						temp.p[i][j]=adjoint().p[i][j]/det;
				return temp;
			}
			catch(int n){
				cout<<"Determinant of Matrix equals zero!"<<endl;
				exit(1);
			}
	}

}

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲高清免费观看高清完整版在线观看| 国内成人免费视频| 九色综合狠狠综合久久| 91色porny蝌蚪| 亚洲精品在线网站| 亚洲大片免费看| 91麻豆国产在线观看| 日韩欧美国产精品| 亚洲一级电影视频| av成人动漫在线观看| 精品国产91亚洲一区二区三区婷婷| 亚洲欧美日韩成人高清在线一区| 国产一区二区毛片| 日韩精品一区二区三区在线 | 久久综合色鬼综合色| 一区二区三区久久久| 国产91在线看| 久久久久久亚洲综合影院红桃| 日韩黄色在线观看| 欧美在线一区二区| 亚洲欧美另类图片小说| www.成人在线| 国产精品免费久久久久| 国产福利精品导航| 久久久国产综合精品女国产盗摄| 精品一区二区三区免费| 欧美电视剧免费观看| 蜜臀av一区二区在线观看| 欧美精品在线观看播放| 五月综合激情婷婷六月色窝| 欧美中文字幕一区二区三区亚洲| 一区二区三区鲁丝不卡| 欧美亚一区二区| 亚洲一区在线电影| 欧美亚洲综合网| 一级精品视频在线观看宜春院| 在线影院国内精品| 亚洲mv在线观看| 91麻豆精品国产综合久久久久久| 午夜激情综合网| 91精品国产色综合久久不卡蜜臀| 免费高清视频精品| 精品成人一区二区| 成人午夜免费av| 国产精品成人午夜| 欧美性受xxxx黑人xyx性爽| 亚洲午夜视频在线| 欧美一区二区三区免费视频| 久久av资源网| 中文字幕欧美日本乱码一线二线| 不卡的电影网站| 一区二区三区欧美亚洲| 91精品国产色综合久久| 国产一区二区三区| 亚洲丝袜另类动漫二区| 精品视频1区2区3区| 蜜臀久久99精品久久久久久9| 久久久99免费| 色噜噜狠狠成人中文综合| 婷婷久久综合九色综合绿巨人| 日韩欧美一区二区三区在线| 国产成人aaa| 亚洲一区二区五区| ww久久中文字幕| 91免费观看视频在线| 秋霞电影网一区二区| 日本一区二区三区电影| 欧美精品v日韩精品v韩国精品v| 国产一区二区三区不卡在线观看| 一区二区三区四区在线免费观看| 欧美一区二区高清| 97精品国产露脸对白| 日韩高清国产一区在线| 欧美激情在线看| 欧美色手机在线观看| 国产激情一区二区三区桃花岛亚洲| 一区二区三区久久| 国产欧美一区在线| 91.xcao| 99这里只有精品| 韩国女主播一区二区三区| 亚洲国产成人va在线观看天堂| 久久久久久久av麻豆果冻| 欧美女孩性生活视频| k8久久久一区二区三区 | 国产成人高清视频| 日韩精品福利网| 亚洲人123区| 国产片一区二区| 日韩免费电影一区| 欧美伊人久久大香线蕉综合69 | 免费成人你懂的| 一区二区国产视频| 国产欧美精品一区| 欧美xfplay| 91精品久久久久久久久99蜜臂| 在线视频你懂得一区二区三区| 成年人午夜久久久| 国产成人精品aa毛片| 国产另类ts人妖一区二区| 欧美aaa在线| 日本欧美一区二区三区| 亚洲大尺度视频在线观看| 亚洲女人的天堂| 亚洲婷婷综合色高清在线| 国产精品视频一二三区 | 欧美r级在线观看| 日韩一级大片在线| 7777女厕盗摄久久久| 欧美日韩国产成人在线免费| 欧美中文一区二区三区| 在线这里只有精品| 欧美亚洲一区二区三区四区| 在线精品视频小说1| 欧美午夜精品一区二区蜜桃| 日本韩国精品一区二区在线观看| 色综合久久久久综合体桃花网| 波多野结衣视频一区| av福利精品导航| 972aa.com艺术欧美| 日本韩国精品在线| 欧美日韩久久一区二区| 日韩一区二区在线观看视频 | 国产午夜精品在线观看| 久久久久国产精品麻豆| 国产精品乱码一区二三区小蝌蚪| 中文字幕色av一区二区三区| 亚洲男人天堂av网| 天堂资源在线中文精品| 免费av网站大全久久| 国产一区二区电影| 成人福利视频在线| 91老司机福利 在线| 欧美日韩高清影院| 日韩精品一区二区三区四区| 国产日韩在线不卡| 亚洲蜜桃精久久久久久久| 亚洲一二三级电影| 蜜臀久久99精品久久久久宅男 | 美国十次了思思久久精品导航| 激情伊人五月天久久综合| 国产·精品毛片| 在线观看视频91| 精品乱人伦一区二区三区| 综合中文字幕亚洲| 日韩国产欧美三级| 成人性生交大合| 欧美精品乱人伦久久久久久| 337p粉嫩大胆噜噜噜噜噜91av| 国产精品女同互慰在线看| 视频在线观看一区二区三区| 国产在线乱码一区二区三区| 色天天综合色天天久久| 精品三级在线观看| 有码一区二区三区| 国产综合色产在线精品| 日本道色综合久久| 久久女同精品一区二区| 亚洲午夜私人影院| 丁香五精品蜜臀久久久久99网站| 欧美撒尿777hd撒尿| 国产日韩精品一区| 日本系列欧美系列| 93久久精品日日躁夜夜躁欧美| 日韩视频在线你懂得| 亚洲精品国产a| 国产成人丝袜美腿| 91精品国产日韩91久久久久久| 亚洲男人的天堂av| 国产1区2区3区精品美女| 91精品国产91热久久久做人人| 成人欧美一区二区三区小说| 国产一区二区美女| 日韩视频一区二区三区 | 久草中文综合在线| 欧美专区在线观看一区| 国产精品护士白丝一区av| 国产制服丝袜一区| 91精品久久久久久久99蜜桃| 亚洲精品高清视频在线观看| av亚洲精华国产精华| 国产亚洲女人久久久久毛片| 蓝色福利精品导航| 在线成人午夜影院| 亚洲第一福利视频在线| 日本电影欧美片| 亚洲人成伊人成综合网小说| 成人av网站在线观看免费| 久久网站热最新地址| 久久99久久久久| 欧美一级搡bbbb搡bbbb| 日韩 欧美一区二区三区| 欧美日韩国产在线观看| 亚洲午夜久久久久久久久电影院| 91美女在线视频| 一区二区三国产精华液| 一本一本大道香蕉久在线精品| 国产精品视频一区二区三区不卡| 国产成人av电影免费在线观看| 国产欧美日韩不卡|