中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

對稱矩陣和稀疏矩陣

發布時間:2020-07-25 03:49:04 來源:網絡 閱讀:305 作者:追夢途中 欄目:編程語言

對稱矩陣

 

Matrix.h

 

#pragma once
 
template<class T>
class SymmetricMatrix
{
public:
 SymmetricMatrix(const T* a, size_t N) //對稱矩陣 只存下三角
:_a(new T[N*(N + 1) / 2])
,_n(N)
{
size_t index = 0;
for (size_t i = 0; i < N; ++i)
{
for (size_t j = 0; j < N; ++j)
{
if (i >= j)
{
_a[index++] = a[i*N + j];
}
else
{
break;
}
}
}
}
 ~SymmetricMatrix()
 {
 }
void Display()
{
for (size_t i = 0; i < _n; ++i)
{
for (size_t j = 0; j <_n; ++j)
{
if (i >= j)//訪問下三角
{
cout << _a[i*(i + 1) / 2 + j] << " ";
}
else  //訪問上三角
{
cout << _a[j*(j + 1) / 2 + i] << " ";
}
}
cout << endl;
}
cout << endl;
}
T& Access(size_t i, size_t j)//訪問i,j這里的數據
{
if (i < j)//若為上三角,交換
{
swap(i, j);
}
return _a[i(i + 1) / 2 + j];
}
protected:
T* _a;
size_t _n;
};
void Test1()
{
int a[5][5] =
{
{ 0, 1, 2, 3, 4 },
{ 1, 0, 1, 2, 3 },
{ 2, 1, 0, 1, 2 },
{ 3, 2, 1, 0, 1 },
{ 4, 3, 2, 1, 0 },
};
SymmetricMatrix<int> sm((int*)a, 5);
sm.Display();
}
 
Test.cpp
 
#include<iostream>
using namespace std;
#include"Matrix.h"
int main()
{
Test1();
system("pause");
return 0;
}


 

對稱矩陣和稀疏矩陣 

 

 

稀疏矩陣

Matrix.h

#include<vector>
template<class T>
struct Triple  //三元組
{
size_t _row;
size_t _col;
T _value;
 
Triple(size_t row=0, size_t col=0, const T& value=T())
:_row(row)
,_col(col)
, _value(value)
 
{}
};
 
template<class T>
class SqarseMatrix  //稀疏矩陣
{
public:
SqarseMatrix(size_t M, size_t N, const T& invalid)
:_M(M)
, _N(N)
, _invalid(invalid)
{}
SqarseMatrix(const T* a, size_t M, size_t N,const T& invalid)
:_M(M)
, _N(N)
, _invalid(invalid)
{
for (size_t i = 0; i < M; ++i)
{
for (size_t j = 0; j < N; ++j)
{
if (a[i*N + j] != invalid)
{
Triple<T> t(i, j, a[i*N + j]);
_a.push_back(t);
}
}
}
}
void Display()
{
size_t index = 0;
for (size_t i = 0; i < _M; ++i)
{
for (size_t j = 0; j <_N; ++j)
{
if (index<_a.size()&&i == _a[index]._row && j == _a[index]._col)//不能超出有效值的范圍
{
cout << _a[index]._value << " ";
++index;
}
else //不是有效值則輸出非法值
{
cout << _invalid << " ";
}
}
cout << endl;
}
cout << endl;
}
SqarseMatrix<T> Transport()  //轉置
{
//o(有效數據的個數*列數)
SqarseMatrix<T> sm(_N,_M,_invalid);
 
for (size_t i = 0; i < _N; ++i)
{
size_t index = 0;
while (index < _a.size())
{
if (_a[index]._col == i)
{
Triple<T> t(_a[index]._col, _a[index]._row, _a[index]._value);
sm._a.push_back(t);
}
++index;
}
}
return sm;
}
 
SqarseMatrix<T> FastTransport()  //快速轉置
{
//O(2*有效數據個數+列數)
SqarseMatrix<T> sm(_N, _M, _invalid);
int* rowCounts = new int[_N];
memset(rowCounts, 0, sizeof(int)*_N);//初始化
 
size_t index = 0;
while (index < _a.size())
{
rowCounts[_a[index]._col]++;
++index;
}
int* rowStart = new int[_N];
rowStart[0] = 0;
for (size_t i = 1; i < _N; ++i)
{
rowStart[i] = rowStart[i - 1] + rowCounts[i - 1];
}
index = 0;
sm._a.resize(_a.size());
while (index < _a.size())
{
size_t row = _a[index]._col;//轉置前的列就是轉置后的行
int& start = rowStart[row];//每行的起始位置,第一個起始位置就是0
Triple<T> t(_a[index]._col, _a[index]._row, _a[index]._value);
sm._a[start] = t;
++start;
 
++index;
}
delete[] rowCounts;
delete[] rowStart;
return sm;
}
protected:
vector<Triple<T>> _a;
size_t _M;
size_t _N;
T _invalid;
};
 
void Test2()
{
int a[6][5] = { { 1, 0, 3, 0, 5 },
                { 0, 0, 0, 0, 0 },
                { 0, 0, 0, 0, 0 },
                { 2, 0, 4, 0, 6 },
                { 0, 0, 0, 0, 0 }};
SqarseMatrix<int> sm((int*)a, 6, 5, 0);
sm.Display();
SqarseMatrix<int> sm2 = sm.Transport();
sm2.Display();
SqarseMatrix<int> sm3 = sm.FastTransport();
sm3.Display();
}
 
Test.cpp
#include<iostream>
using namespace std;
#include"Matrix.h"
int main()
{
//Test1();
Test2();
system("pause");
return 0;
}

對稱矩陣和稀疏矩陣

 

 

 

 

 

 

 


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南川市| 金溪县| 垫江县| 安丘市| 德格县| 邵阳县| 门源| 洛川县| 奉节县| 舞阳县| 宣化县| 会理县| 宝清县| 东安县| 尼木县| 哈巴河县| 定日县| 庐江县| 达日县| 萝北县| 宜宾市| 金塔县| 五家渠市| 宽甸| 简阳市| 资兴市| 湛江市| 井冈山市| 治县。| 顺昌县| 安泽县| 盐源县| 隆回县| 登封市| 深水埗区| 都兰县| 饶平县| 克什克腾旗| 吴旗县| 大田县| 建水县|