- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
你好,我有一个家庭作业,我需要将两个矩阵 .txt 文件读入两个链表(存储列、行和值),然后将两个列表相加并打印出求和矩阵。
将矩阵读入链表和将这些列表打印为矩阵一样工作正常。但是我坚持如何将这两个列表添加在一起。理想情况下,如果在将一个列表与另一个列表进行比较时列值和行值相同,则应将该值相加。如果它们不相同,那么它应该只打印值。我认为创建一个新列表的组合列表的大小然后比较元素并添加所有其他元素是可行的方法但我似乎无法让它比节点更先进。
在此先感谢您的帮助。
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <fstream>
#include <sstream>
using namespace std;
struct Node {
int row;
int column;
int value;
Node *next;
};
Node *A, *B, *C;
//Add node function.
void addNode( Node *& listpointer, int r, int c, int v ) {
Node *temp;
temp = new Node;
temp->row = r;
temp->column = c;
temp->value = v;
temp->next = listpointer;
listpointer = temp;
}
//Matrix row file size function.
int getRowSize ( char *file_name ){
int row = 0;
int nothing = 0;
ifstream input;
string line;
input.open(file_name);
if(!input.good()){
cout << "Cannot open file " << file_name << endl;
exit(0);
}
if(input.good()){
getline(input,line);
stringstream sline(line);
sline >> row >> nothing;
}
return row;
}
//Matrix column file size function.
int getColumnSize ( char *file_name ){
int column = 0;
int nothing = 0;
ifstream input;
string line;
input.open(file_name);
if(!input.good()){
cout << "Cannot open file " << file_name << endl;
exit(0);
}
if(input.good()){
getline(input,line);
stringstream sline(line);
sline >> nothing >> column;
}
return column;
}
//Read from file to LL function.
void readMatrix( Node* &a, char *file_name ){
int row = getRowSize(file_name);
int col = getColumnSize(file_name);
//cout << "Row = " << row <<" Column = "<< col <<endl;
int value = 0;
string line;
ifstream input;
input.open(file_name);
if(!input.good()){
cout << "Cannot open file " << file_name << endl;
exit(0);
}
if(input.good()){
getline(input,line);
stringstream sline(line);
sline >> row >> col;
//cout << "Matrix dimensions " << row << " " << col << endl;
}
for(int i = 0; i < row; ++i){
if(input.good()) {
getline(input,line);
stringstream sline(line);
for(int j = 0; j < col; ++j){
sline >> value;
if(value == 0) continue;
addNode(a, i, j, value);
//cout << "Element at (" << i << " " << j << ") is different than zero and it is: "<< value <<" \n";
}
//cout << endl;
}
}
input.close();
}
//Search function for print function.
int searchByPosition ( Node *listpointer, int r, int c){
Node *current;
current = listpointer;
while ( true ){
if ( current == NULL ){ break; }
if (r == current->row && c == current->column) {
//cout << "Value = " << x << "\n";
return current->value;
}
current = current->next;
}
//cout << "Value not in list.\n";
return 0;
}
//Print function.
void printMatrix ( Node *listpointer, int columnSize, int rowSize ){
int c, r, v;
for (r=0; r < rowSize; ++r) {
for (c=0; c < columnSize; ++c) {
v = searchByPosition(listpointer,r,c);
printf("%d ", v);
}
printf("\n");
}
printf("\n");
}
//Function that mneasures both lists and creates a new combined list.
void concatenate ( Node *&result, Node *listpointer1, Node *listpointer2){
Node *tempLP1, *tempLP2, *countLP1, *countLP2;
countLP1 = listpointer1;
countLP2 = listpointer2;
tempLP1 = listpointer1;
tempLP2 = listpointer2;
int listpointer1Size = 0;
int listpointer2Size = 0;
while ( countLP1 != NULL ) {
++listpointer1Size;
countLP1 = countLP1->next;
}
//cout << listpointer1Size <<endl;
while ( countLP2 != NULL ) {
++listpointer2Size;
countLP2 = countLP2->next;
}
//cout << listpointer2Size;
int resultSize = listpointer1Size + listpointer2Size;
//cout << resultSize;
for (int i=0; i < resultSize; ++i) {
if (tempLP1->column == tempLP2->column && tempLP1->row == tempLP2->row) {
//cout << result->value<<" "<<result->row<<" "<<result->column<<endl;
addNode(result, tempLP1->row, tempLP1->column, (tempLP1->value + tempLP2->value));
//cout <<"marker "<<i+1<<endl;
//result = result->next;
tempLP1 = tempLP1->next;
//cout << tempLP1->value<<" "<<tempLP1->row<<" "<<tempLP1->column<<endl;
//cout << result->value<<" "<<result->row<<" "<<result->column<<endl;
} else {
addNode(result, tempLP1->row, tempLP1->column, tempLP1->value);
//cout << tempLP1->value<<" "<<tempLP1->row<<" "<<tempLP1->column<<endl;
tempLP1 = tempLP1->next;
//addNode(result, listpointer2->row, listpointer2->column, listpointer2->value);
//cout <<"marker2"<<endl;
//cout << listpointer1->value;
//result = result->next;
//listpointer1 = listpointer1->next;
}
}
/*current = listpointer1;
prev = NULL;
while ( current != NULL ){
prev = current;
current = current->next;
}
if ( prev == NULL ){
//cout <<"List1 was empty, joining anyway.\n";
listpointer1 = listpointer2;
} else {
//cout <<"Join.\n";
prev->next = listpointer2;
}*/
}
int main() {
A = NULL; // ALL linked-lists start empty
B = NULL; // ALL linked-lists start empty
C = NULL; // ALL linked-lists start empty
readMatrix(A, (char*)"matrix1.txt");
readMatrix(B, (char*)"matrix2.txt");
int rowSize1 = getRowSize((char*)"matrix1.txt");
int colSize1 = getColumnSize((char*)"matrix1.txt");
//cout << rowSize << colSize;
printMatrix(A, rowSize1, colSize1);
printMatrix(B, rowSize1, colSize1);
concatenate(C, A, B);
//printMatrix(C, rowSize1, colSize1);
//printMatrix(B, rowSize1, colSize1);
}
最佳答案
下面是一些代码,可以将存储在链表中的两个 2 x 2
矩阵相加。
#include <stdio.h>
#include <stdlib.h>
typedef struct node {
int row;
int column;
int value;
struct node *next;
} Node;
void main()
{
int prev_node_row = 0;
Node * matrix1;
Node * matrix2;
Node * m1cur;
Node * m2cur;
Node m1n0 = {0,0,1,NULL};
Node m1n1 = {0,1,2,NULL};
Node m1n2 = {1,0,3,NULL};
Node m1n3 = {1,1,4,NULL};
Node m2n0 = {0,0,5,NULL};
Node m2n1 = {0,1,6,NULL};
Node m2n2 = {1,0,7,NULL};
Node m2n3 = {1,1,8,NULL};
matrix1 = &m1n0;
m1n0.next = &m1n1;
m1n1.next = &m1n2;
m1n2.next = &m1n3;
matrix2 = &m2n0;
m2n0.next = &m2n1;
m2n1.next = &m2n2;
m2n2.next = &m2n3;
m1cur = matrix1;
m2cur = matrix2;
while (m1cur != NULL && m2cur != NULL)
{
if (prev_node_row < m1cur->row)
{
printf("\n");
}
printf("%d ", m1cur->value + m2cur->value);
prev_node_row = m1cur->row;
m1cur = m1cur->next;
m2cur = m2cur->next;
}
}
初始化矩阵 1
1 2
3 4
初始化矩阵 2
5 6
7 8
输出
6 8
10 12
关于c++ - 将两个链表中的特定值相加时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9693986/
SQLite、Content provider 和 Shared Preference 之间的所有已知区别。 但我想知道什么时候需要根据情况使用 SQLite 或 Content Provider 或
警告:我正在使用一个我无法完全控制的后端,所以我正在努力解决 Backbone 中的一些注意事项,这些注意事项可能在其他地方更好地解决......不幸的是,我别无选择,只能在这里处理它们! 所以,我的
我一整天都在挣扎。我的预输入搜索表达式与远程 json 数据完美配合。但是当我尝试使用相同的 json 数据作为预取数据时,建议为空。点击第一个标志后,我收到预定义消息“无法找到任何内容...”,结果
我正在制作一个模拟 NHL 选秀彩票的程序,其中屏幕右侧应该有一个 JTextField,并且在左侧绘制弹跳的选秀球。我创建了一个名为 Ball 的类,它实现了 Runnable,并在我的主 Draf
这个问题已经有答案了: How can I calculate a time span in Java and format the output? (18 个回答) 已关闭 9 年前。 这是我的代码
我有一个 ASP.NET Web API 应用程序在我的本地 IIS 实例上运行。 Web 应用程序配置有 CORS。我调用的 Web API 方法类似于: [POST("/API/{foo}/{ba
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
放宽“邻居”的标准是否足够,或者是否有其他标准行动可以采取? 最佳答案 如果所有相邻解决方案都是 Tabu,则听起来您的 Tabu 列表的大小太长或您的释放策略太严格。一个好的 Tabu 列表长度是
我正在阅读来自 cppreference 的代码示例: #include #include #include #include template void print_queue(T& q)
我快疯了,我试图理解工具提示的行为,但没有成功。 1. 第一个问题是当我尝试通过插件(按钮 1)在点击事件中使用它时 -> 如果您转到 Fiddle,您会在“内容”内看到该函数' 每次点击都会调用该属
我在功能组件中有以下代码: const [ folder, setFolder ] = useState([]); const folderData = useContext(FolderContex
我在使用预签名网址和 AFNetworking 3.0 从 S3 获取图像时遇到问题。我可以使用 NSMutableURLRequest 和 NSURLSession 获取图像,但是当我使用 AFHT
我正在使用 Oracle ojdbc 12 和 Java 8 处理 Oracle UCP 管理器的问题。当 UCP 池启动失败时,我希望关闭它创建的连接。 当池初始化期间遇到 ORA-02391:超过
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve
引用这个plunker: https://plnkr.co/edit/GWsbdDWVvBYNMqyxzlLY?p=preview 我在 styles.css 文件和 src/app.ts 文件中指定
为什么我的条形这么细?我尝试将宽度设置为 1,它们变得非常厚。我不知道还能尝试什么。默认厚度为 0.8,这是应该的样子吗? import matplotlib.pyplot as plt import
当我编写时,查询按预期执行: SELECT id, day2.count - day1.count AS diff FROM day1 NATURAL JOIN day2; 但我真正想要的是右连接。当
我有以下时间数据: 0 08/01/16 13:07:46,335437 1 18/02/16 08:40:40,565575 2 14/01/16 22:2
一些背景知识 -我的 NodeJS 服务器在端口 3001 上运行,我的 React 应用程序在端口 3000 上运行。我在 React 应用程序 package.json 中设置了一个代理来代理对端
我面临着一个愚蠢的问题。我试图在我的 Angular 应用程序中延迟加载我的图像,我已经尝试过这个2: 但是他们都设置了 src attr 而不是 data-src,我在这里遗漏了什么吗?保留 d
我是一名优秀的程序员,十分优秀!