ImageVerifierCode 换一换
格式:DOCX , 页数:103 ,大小:35.38KB ,
资源ID:7495920      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7495920.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(matrix运算c代码.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

matrix运算c代码.docx

1、matrix运算c代码/ Construction/Destruction/ Matrix.cpp/ 操作矩阵的类 CMatrix 的实现文件/ 周长发编制, 2002/8/#include stdafx.h#include Matrix.h#ifdef _DEBUG#undef THIS_FILEstatic char THIS_FILE=_FILE_;#define new DEBUG_NEW#endif/ Construction/Destruction/ 基本构造函数/CMatrix:CMatrix() m_nNumColumns = 1; m_nNumRows = 1; m_pDat

2、a = NULL; BOOL bSuccess = Init(m_nNumRows, m_nNumColumns); ASSERT(bSuccess);/ 指定行列构造函数/ 参数:/ 1. int nRows - 指定的矩阵行数/ 2. int nCols - 指定的矩阵列数/CMatrix:CMatrix(int nRows, int nCols) m_nNumRows = nRows; m_nNumColumns = nCols; m_pData = NULL; BOOL bSuccess = Init(m_nNumRows, m_nNumColumns); ASSERT(bSucces

3、s);/ 指定值构造函数/ 参数:/ 1. int nRows - 指定的矩阵行数/ 2. int nCols - 指定的矩阵列数/ 3. double value - 一维数组,长度为nRows*nCols,存储矩阵各元素的值/CMatrix:CMatrix(int nRows, int nCols, double value) m_nNumRows = nRows; m_nNumColumns = nCols; m_pData = NULL; BOOL bSuccess = Init(m_nNumRows, m_nNumColumns); ASSERT(bSuccess); SetData

4、(value);/ 方阵构造函数/ 参数:/ 1. int nSize - 方阵行列数/CMatrix:CMatrix(int nSize) m_nNumRows = nSize; m_nNumColumns = nSize; m_pData = NULL; BOOL bSuccess = Init(nSize, nSize); ASSERT (bSuccess);/ 方阵构造函数/ 参数:/ 1. int nSize - 方阵行列数/ 2. double value - 一维数组,长度为nRows*nRows,存储方阵各元素的值/CMatrix:CMatrix(int nSize, doub

5、le value) m_nNumRows = nSize; m_nNumColumns = nSize; m_pData = NULL; BOOL bSuccess = Init(nSize, nSize); ASSERT (bSuccess); SetData(value);/ 拷贝构造函数/ 参数:/ 1. const CMatrix& other - 源矩阵/CMatrix:CMatrix(const CMatrix& other) m_nNumColumns = other.GetNumColumns(); m_nNumRows = other.GetNumRows(); m_pDat

6、a = NULL; BOOL bSuccess = Init(m_nNumRows, m_nNumColumns); ASSERT(bSuccess); / copy the pointer memcpy(m_pData, other.m_pData, sizeof(double)*m_nNumColumns*m_nNumRows);/ 析构函数/CMatrix:CMatrix() if (m_pData) delete m_pData; m_pData = NULL; / 初始化函数/ 参数:/ 1. int nRows - 指定的矩阵行数/ 2. int nCols - 指定的矩阵列数/

7、返回值:BOOL 型,初始化是否成功/BOOL CMatrix:Init(int nRows, int nCols) if (m_pData) delete m_pData; m_pData = NULL; m_nNumRows = nRows; m_nNumColumns = nCols; int nSize = nCols*nRows; if (nSize 0) return FALSE; / 分配内存 m_pData = new doublenSize; if (m_pData = NULL) return FALSE; / 内存分配失败 if (IsBadReadPtr(m_pData

8、, sizeof(double) * nSize) return FALSE; / 将各元素值置0 memset(m_pData, 0, sizeof(double) * nSize); return TRUE;/ 将方阵初始化为单位矩阵/ 参数:/ 1. int nSize - 方阵行列数/ 返回值:BOOL 型,初始化是否成功/BOOL CMatrix:MakeUnitMatrix(int nSize) if (! Init(nSize, nSize) return FALSE; for (int i=0; inSize; +i) for (int j=0; jnSize; +j) if

9、(i = j) SetElement(i, j, 1); return TRUE;/ 将字符串转化为矩阵的值/ 参数:/ 1. CString s - 数字和分隔符构成的字符串/ 2. const CString& sDelim - 数字之间的分隔符,默认为空格/ 3. BOOL bLineBreak - 行与行之间是否有回车换行符,默认为真(有换行符)/ 当该参数为FALSE时,所有元素值都在一行中输入,字符串的第一个/ 数值应为矩阵的行数,第二个数值应为矩阵的列数/ 返回值:BOOL 型,转换是否成功/BOOL CMatrix:FromString(CString s, const CSt

10、ring& sDelim /*= */, BOOL bLineBreak /*= TRUE*/) if (s.IsEmpty() return FALSE; / 分行处理 if (bLineBreak) CTokenizer tk(s, rn); CStringList ListRow; CString sRow; while (tk.Next(sRow) sRow.TrimLeft(); sRow.TrimRight(); if (sRow.IsEmpty() break; ListRow.AddTail(sRow); / 行数 m_nNumRows = ListRow.GetCount()

11、; sRow = ListRow.GetHead(); CTokenizer tkRow(sRow, sDelim); CString sElement; / 列数 m_nNumColumns = 0; while (tkRow.Next(sElement) m_nNumColumns+; / 初始化矩阵 if (! Init(m_nNumRows, m_nNumColumns) return FALSE; / 设置值 POSITION pos = ListRow.GetHeadPosition(); for (int i=0; im_nNumRows; i+) sRow = ListRow.

12、GetNext(pos); int j = 0; CTokenizer tkRow(sRow, sDelim); while (tkRow.Next(sElement) sElement.TrimLeft(); sElement.TrimRight(); double v = atof(sElement); SetElement(i, j+, v); return TRUE; / 不分行(单行)处理 CTokenizer tk(s, sDelim); CString sElement; / 行数 tk.Next(sElement); sElement.TrimLeft(); sElement.

13、TrimRight(); m_nNumRows = atoi(sElement); / 列数 tk.Next(sElement); sElement.TrimLeft(); sElement.TrimRight(); m_nNumColumns = atoi(sElement); / 初始化矩阵 if (! Init(m_nNumRows, m_nNumColumns) return FALSE; / 设置值 int i = 0, j = 0; while (tk.Next(sElement) sElement.TrimLeft(); sElement.TrimRight(); double

14、v = atof(sElement); SetElement(i, j+, v); if (j = m_nNumColumns) j = 0; i+; if (i = m_nNumRows) break; return TRUE; / 将矩阵各元素的值转化为字符串/ 参数:/ 1. const CString& sDelim - 数字之间的分隔符,默认为空格/ 2 BOOL bLineBreak - 行与行之间是否有回车换行符,默认为真(有换行符)/ 返回值:CString 型,转换得到的字符串/CString CMatrix:ToString(const CString& sDelim /*

15、= */, BOOL bLineBreak /*= TRUE*/) const CString s=; for (int i=0; im_nNumRows; +i) for (int j=0; j= m_nNumRows) return s; for (int j=0; j= m_nNumColumns) return s; for (int i=0; im_nNumRows; +i) CString ss; ss.Format(%f, GetElement(i, nCol); s += ss; if (i != m_nNumRows-1) s += sDelim; return s;/ 设置

16、矩阵各元素的值/ 参数:/ 1. double value - 一维数组,长度为m_nNumColumns*m_nNumRows,存储/ 矩阵各元素的值/ 返回值:无/void CMatrix:SetData(double value) / empty the memory memset(m_pData, 0, sizeof(double) * m_nNumColumns*m_nNumRows); / copy data memcpy(m_pData, value, sizeof(double)*m_nNumColumns*m_nNumRows);/ 设置指定元素的值/ 参数:/ 1. int

17、 nRows - 指定的矩阵行数/ 2. int nCols - 指定的矩阵列数/ 3. double value - 指定元素的值/ 返回值:BOOL 型,说明设置是否成功/BOOL CMatrix:SetElement(int nRow, int nCol, double value) if (nCol = m_nNumColumns | nRow = m_nNumRows) return FALSE;/ array bounds error if (m_pData = NULL) return FALSE;/ bad pointer error m_pDatanCol + nRow * m_nNumColumns = value; return TRUE;/ 设置指定元素的值/ 参

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1