描写叙述:

输入两个稀疏矩阵A和B,用十字链表实现A=A+B,输出它们相加的结果。

输入:

第一行输入四个正整数,各自是两个矩阵的行m、列n、第一个矩阵的非零元素的个数t1和第二个矩阵的非零元素的个数t2,接下来的t1+t2行是三元组,各自是第一个矩阵的数据和第二个矩阵的数据, 三元组的第一个元素表示行,第二个元素表示列,第三个元素是该元素的值。

输出:

输出相加后的矩阵三元组。

输入例子:


3 4 3 2
1 1 1
1 3 1
2 2 2
1 2 1
2 2 3

输出例子:


1 1 1
1 2 1
1 3 1
2 2 5
#include <stdio.h>
#include<stdlib.h> typedef struct OLNODE
{
int row,col;
int data;
struct OLNODE *right,*down;
} NODE,*LNODE; typedef struct CORSS
{
LNODE *rh,*ch;
int ra,ca,da;
} CROSS, *LCROSS; void Create(LCROSS A); void PlusToA(LCROSS A,LCROSS B); void PrintCross(LCROSS A); int main()
{
LCROSS A = (LCROSS)malloc(sizeof(CROSS));
LCROSS B = (LCROSS)malloc(sizeof(CROSS)); scanf("%d %d %d %d",&A->ra,&A->ca,&A->da,&B->da);
B->ra = A->ra;
B->ca = A->ca; Create(A);
Create(B);//" 3 4 0 5 创建时B有问题"
PlusToA(A,B);
PrintCross(A);
return 0;
} void Create(LCROSS M)
{
int i;
LNODE p,temp; M->rh = (LNODE *)malloc((M->ra+1)*sizeof(LNODE));
M->ch = (LNODE *)malloc((M->ca+1)*sizeof(LNODE)); for(i=1; i<=M->ra; i++)
{
M->rh[i]=NULL;
}
/*for(i=1; i<=M->ca; i++)
{
M->ch[i]=NULL;
}*/ if(M->da != 0)
{
for(i=1; i<=M->da; i++)
{
p=(LNODE)malloc(sizeof(NODE));
scanf("%d %d %d",&p->row,&p->col,&p->data);
if(M->rh[p->row] == NULL)
{
p->right=NULL;
M->rh[p->row] = p; }
else
{
for(temp=M->rh[p->row];; temp=temp->right)
{
if(temp->right == NULL)
{
temp->right = p;
p->right =NULL;
break;
}
else if(temp->col < p->col && temp->right->col>p->col)
{
p->right = temp->right;
temp->right = p;
break;
}
else if(temp==M->rh[p->row] && temp->col>p->col)
{
p->right = temp;
temp=p;
break;
}
} } /* if(M->ch[p->col] == NULL|| M->ch[p->col]->row>(p->row))
{ p->down=M->ch[p->col];
M->ch[p->col] = p;
}
else
{
for(temp=M->ch[p->col]; temp->down && temp->down->row<p->row; temp=temp->down); p->down = temp->down;
temp->down = p;
}*/
}
} } void PlusToA(LCROSS A,LCROSS B)
{
int i;
LNODE p,temp1,temp2;
for(i=1; i<=A->ra; i++)
{
if(B->rh[i] == NULL) continue;
else
{
if(A->rh[i] == NULL)
{ p=(LNODE)malloc(sizeof(NODE));
p->col = B->rh[i]->col;
p->row = B->rh[i]->row;
p->data = B->rh[i]->data;
A->rh[i]=p;
p->right = NULL;
B->rh[i]=B->rh[i]->right; }
if(B->rh[i]==NULL)continue;
for(temp1=B->rh[i];; temp1=temp1->right)
{
for(temp2=A->rh[i];; temp2=temp2->right)
{
if(temp2->col == temp1->col)
{
temp2->data+=temp1->data;
break;
}
else if(temp2==A->rh[i] && temp1->col<temp2->col)
{
p=(LNODE)malloc(sizeof(NODE));
p->col = temp1->col;
p->row = temp1->row;
p->data = temp1->data;
p->right = temp2->right;
p->right =temp2;
A->rh[i]=p;
break;
}
else if((temp2->right == NULL || temp2->right->col>temp1->col) && temp1->col>temp2->col)
{
p=(LNODE)malloc(sizeof(NODE));
p->col = temp1->col;
p->row = temp1->row;
p->data = temp1->data;
p->right = temp2->right;
temp2->right=p;
break;
} } if(temp1->right == NULL) break;
}
}
} } void PrintCross(LCROSS A)
{
int i;
LNODE p;
for(i=1; i<=A->ra; i++)
{
p=A->rh[i];
while(p!=NULL)
{
printf("%d %d %d\n",p->row,p->col,p->data);
p=p->right;
}
}
}

TIP:

1、仅使用了十字链表中的行链表,列链表被凝视掉了,由于本题中没用。

2、注意改动链表时一定要改动原链表变量!!

如,定义链表A。temp=A。改动temp=p不能达到改动链表A=p的目的。

稀疏矩阵的加法(用十字链表实现A=A+B)的更多相关文章

  1. 利用十字链表压缩稀疏矩阵(c++)-- 数据结构

    题目: 7-1 稀疏矩阵 (30 分)   如果一个矩阵中,0元素占据了矩阵的大部分,那么这个矩阵称为“稀疏矩阵”.对于稀疏矩阵,传统的二维数组存储方式,会使用大量的内存来存储0,从而浪费大量内存.为 ...

  2. javascript实现数据结构:稀疏矩阵的十字链表存储表示

    当矩阵的非零个数和位置在操作过程中变化大时,就不宜采用顺序存储结构来表示三元组的线性表.例如,在作“将矩阵B加到矩阵A上”的操作时,由于非零元的插入或删除将会引起A.data中元素的移动.为此,对这种 ...

  3. [game]十字链表的AOI算法实现

    AOI主要有九宫格.灯塔和十字链表的算法实现.本文阐述十字链表的实现和尝试. 1. 基本原理 根据二维地图,将其分成x轴和y轴两个链表.如果是三维地图,则还需要维护多一个z轴的链表.将对象的坐标值按照 ...

  4. 稀疏矩阵乘法加法等的java实现

    原创声明:本文系作者原创,转载请写明出处. 一.前言       前几天由于科研需要,一直在搞矩阵的稀疏表示的乘法,不过最近虽然把程序写出来了,还是无法处理大规模的矩阵(虽然已经是稀疏了).原因可能是 ...

  5. 十字链表 Codeforces Round #367 E Working routine

    // 十字链表 Codeforces Round #367 E Working routine // 题意:给你一个矩阵,q次询问,每次交换两个子矩阵,问最后的矩阵 // 思路:暴力肯定不行.我们可以 ...

  6. 数据结构C语言版 有向图的十字链表存储表示和实现

    /*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...

  7. 图->存储结构->十字链表

    文字描述 十字链表是有向图的另一种链式存储结构. 在十字链表中,对应于有向图中每一条弧有一个结点,对应于每个顶点也有一个结点.这些结点的结构如下所示: 在弧结点中有5个域: 尾域tailvex和头域h ...

  8. 数据结构之BF算法,kmp算法,三元组,十字链表总结

    在这一章中,老师教了我们四种数据结构:BF算法,kmp算法,三元组和十字链表:还给我们讲了2019年团体天体赛中T1-8的AI题 1.对于BF和kmp算法,老师除了在课堂上讲解算法的主要核心思想外,还 ...

  9. 数据结构之---C++语言实现图的十字链表存储表示

    近期一直忙着考研复习,非常久都没有更新博客了.今天写一篇数据结构的存储. //有向图的十字链表存储表示 //杨鑫 #include <iostream> #include <cstd ...

随机推荐

  1. 分布式中使用redis进行session共享

    摘要 在asp.net web中,session经常用来存储当前用户信息,或者通过session进行登录权限的验证.如果是一台服务器,session的使用没问题,如果使用nginx等实现反向代理,将站 ...

  2. 用最简单的例子理解命令模式(Command Pattern)

    假设想让遥控器控制电灯的开关.电视机的开关和切换,该如何做? 所有的开.关.切换都是遥控器发出的指令,把这些指令统一抽象成一个接口. public interface IControl { void ...

  3. jQuery异步获取json数据的2种方式

    jQuery异步获取json数据有2种方式,一个是$.getJSON方法,一个是$.ajax方法.本篇体验使用这2种方式异步获取json数据,然后追加到页面. 在根目录下创建data.json文件: ...

  4. Spring Boot1.5X升级到2.0指南

    原文:https://www.jianshu.com/p/3494c84b4be3 前言 Spring Boot已经发布2.0有4个月多,多了很多新特性,一些坑也慢慢被填上,最近有空,就把本博客中Sp ...

  5. gflags摘记

    projcet url: https://github.com/schuhschuh/gflags usage: commandline flags processing DEFINE: Defini ...

  6. 将properties文件放在Jar包并读取

    有时候需要在一个library内部打包一个properties文件,包含一些配置信息,而不能部署在外部. 在maven工程里面,将properties文件放在src/main/resources目录下 ...

  7. C++“窗体”程序设计启蒙(之二)

    [摘要]本文适合已经完整学习了C++面向对象机制,但在开发窗体程序方面还是零基础的同学.通过本文的引导进行实践体验,目的是消除同学们开发窗体程序的神奇感,为下一步的自学找到感觉.同一时候,能更深入地体 ...

  8. 跟我学Spring3(9.1):Spring的事务之数据库事务概述

    原文出处: 张开涛 9.1 数据库事务概述 事务首先是一系列操作组成的工作单元,该工作单元内的操作是不可分割的,即要么所有操作都做,要么所有操作都不做,这就是事务. 事务必需满足ACID(原子性.一致 ...

  9. coursera课程Text Retrieval and Search Engines之Week 3 Overview

    Week 3 OverviewHelp Center Week 3 On this page: Instructional Activities Time Goals and Objectives K ...

  10. Java并发学习之十五——使用读写锁同步数据訪问

    本文是学习网络上的文章时的总结.感谢大家无私的分享. 读写锁重要的是写锁的使用,仅仅用一个入口. 以下是读写锁使用的样例 package chapter2; import java.util.conc ...