#include using namespace std; struct Triple { int row, col, value; }; class Matrix; class MatrixNode { friend class Matrix; friend istream& operator>>(istream&, Matrix&); private: MatrixNode *down, *right; bool head; union { MatrixNode *next; Triple triple; }; MatrixNode(bool, Triple*); }; MatrixNode::MatrixNode(bool b, Triple *t) { head = b; if (b) { right = down = this; } else triple = *t; }; class Matrix { friend istream& operator>>(istream&, Matrix&); public: ~Matrix(); MatrixNode* private: MatrixNode *headnode; }; Matrix::~Matrix() {// Return all nodes to the av list, which is a chain linked // via the right field. // av is a static variable pointing to the first of the av list. if (!headnode ) return; // no nodes to delete MatrixNode *x = headnode->right; headnode->right = av; av = headnode; // return headnode while (x != headnode) { // return nodes by rows MatrixNode *y = x->right; x->right = av; av = y; x = x->next; // next row } headnode = 0; } istream& operator>>(istream& is, Matrix& matrix) { // Read in a maxtix and set up its linked representation Triple s; is >> s.row >> s.col >> s.value; // matrix dimensions int p = max(s.row, s.col); // set up header node for list of header nodes matrix.headnode = new MatrixNode(false, &s); if (p == 0) { matrix.headnode->right = matrix.headnode; return is; // for supporting "cin >> mi >> mj;" } // at least one row or column MatrixNode **head = new MatrixNode* [p]; for (int i = 0; i < p; i++) head[i] = new MatrixNode(true, 0); // please continue on the next page int currentRow = 0; MatrixNode* last = head[0]; // last node in current row for (int i = 0; i < s.value; i++) // input triples { Triple t; is >> t.row >> t.col >> t.value; if (t.row > currentRow) // end of current row { last->right = head[currentRow]; // close current row currentRow = t.row; last = head[currentRow]; } // end of if last = last->right = new MatrixNode(false, &t); // link new node into row list head[t.col]->next = head[t.col]->next->down = last; // link into column list } // end of for // please continue on the next page last->right = head[currentRow]; // close last row for (int i = 0; i < s.col; i++) head[i]->next->down = head[i]; // close all column lists // link the header nodes together for (int i = 0; i < p; i++) head[i]->next = head[i + 1]; head[p-1]->next = matrix.headnode; matrix.headnode->right = head[0]; delete [] head; return is; } int main() { Matrix m, n, k; cin >> m >> n >>k; cout << "Hello world!" << endl; return 0; }
#include <iostream>
using namespace std;
struct Triple
{
int row, col, value;
};
class Matrix;
class MatrixNode
{
friend class Matrix;
friend istream& operator>>(istream&, Matrix&);
private:
MatrixNode *down, *right;
bool head;
union
{
MatrixNode *next;
Triple triple;
};
MatrixNode(bool, Triple*);
};
MatrixNode::MatrixNode(bool b, Triple *t)
{
head = b;
if (b)
{
right = down = this;
}
else triple = *t;
};
class Matrix
{
friend istream& operator>>(istream&, Matrix&);
public:
~Matrix();
MatrixNode*
private:
MatrixNode *headnode;
};
Matrix::~Matrix()
{// Return all nodes to the av list, which is a chain linked
// via the right field.
// av is a static variable pointing to the first of the av list.
if (!headnode )
return; // no nodes to delete
MatrixNode *x = headnode->right;
headnode->right = av;
av = headnode; // return headnode
while (x != headnode) { // return nodes by rows
MatrixNode *y = x->right;
x->right = av;
av = y;
x = x->next; // next row
}
headnode = 0;
}
istream& operator>>(istream& is, Matrix& matrix)
{
// Read in a maxtix and set up its linked representation
Triple s;
is >> s.row >> s.col >> s.value; // matrix dimensions
int p = max(s.row, s.col);
// set up header node for list of header nodes
matrix.headnode = new MatrixNode(false, &s);
if (p == 0)
{
matrix.headnode->right = matrix.headnode;
return is; // for supporting "cin >> mi >> mj;"
}
// at least one row or column
MatrixNode **head = new MatrixNode* [p];
for (int i = 0; i < p; i++)
head[i] = new MatrixNode(true, 0);
// please continue on the next page
int currentRow = 0;
MatrixNode* last = head[0]; // last node in current row
for (int i = 0; i < s.value; i++) // input triples
{
Triple t;
is >> t.row >> t.col >> t.value;
if (t.row > currentRow) // end of current row
{
last->right = head[currentRow]; // close current row
currentRow = t.row;
last = head[currentRow];
} // end of if
last = last->right = new MatrixNode(false, &t);
// link new node into row list
head[t.col]->next = head[t.col]->next->down = last;
// link into column list
} // end of for
// please continue on the next page
last->right = head[currentRow]; // close last row
for (int i = 0; i < s.col; i++)
head[i]->next->down = head[i]; // close all column lists
// link the header nodes together
for (int i = 0; i < p; i++)
head[i]->next = head[i + 1];
head[p-1]->next = matrix.headnode;
matrix.headnode->right = head[0];
delete [] head;
return is;
}
int main()
{
Matrix m, n, k;
cin >> m >> n >>k;
cout << "Hello world!" << endl;
return 0;
}
Based on this class, do the following tasks.
(a) Write the C++ function, operator+(const Matrix& b) const, which returns the matrix *this + b.
(b) Write the C++ function, operator*(const Matrix& b) const, which returns the matrix *this * b.
(c) Write the C++ function, operator<<(), which outputs a sparse matrix as triples (i, j, aij).
(d) Write the C++ function, Transpose(), which transpose a sparse matrix.
(e) Write and test a copy constructor for sparse matrices. What is the computing time of your copy constructor?
Note:
I have tried to code it, but the overloaded operator>> has a bug, I think it's this line "head[t.col]->next = head[t.col]->next->down = last;". for illustration I attach two pictures.
data:image/s3,"s3://crabby-images/5aa16/5aa16538725bdf867b99f818e52b82430ad2403a" alt="Sparse Matrices
A UNIVE
Array-based representation (we have learned this before)
• Row access is easy, but column access is difficult
• Linked representation
Easy access both by row and column
Node design (head field will not be shown later)
Handler
Terms
Row/Col Head
#row #col #terms
row
col
val
next
down
right
down
right
down
right
ishead
ishead
ishead
ishead = false
ishead = true
139"
data:image/s3,"s3://crabby-images/4d0e6/4d0e625622b73b7480ec2f10a129905e115234a3" alt="Linked Sparse Matrix
но
wwww
Н4
H1
H2
H3
4
6.
H
но
2
H1
1
4
13 3
Н2
2 00
4 0 0 3
0 0 0
H3
3
8
3 3
8
1
0 6
4 2
6.
Н4
140"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Step by step
Solved in 2 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/7daab/7daab2e89d2827b6568a3205a22fcec2da31a567" alt="Concepts of Database Management"
data:image/s3,"s3://crabby-images/cd999/cd999b5a0472541a1bb53dbdb5ada535ed799291" alt="Prelude to Programming"
data:image/s3,"s3://crabby-images/39e23/39e239a275aed535da3161bba64f5416fbed6c8c" alt="Sc Business Data Communications and Networking, T…"