数据结构实验之数组三:快速转置

Time Limit: 1000 ms Memory Limit: 65536 KiB

Problem Description

转置运算是一种最简单的矩阵运算,对于一个m*n的矩阵M( 1 = < m < = 10000,1 = < n < = 10000 ),它的转置矩阵T是一个n*m的矩阵,且T( i , j )=M( j , i )。显然,一个稀疏矩阵的转置仍然是稀疏矩阵。你的任务是对给定一个m*n的稀疏矩阵( m , n < = 10000 ),求该矩阵的转置矩阵并输出。矩阵M和转置后的矩阵T如下图示例所示。

稀疏矩阵M



稀疏矩阵T

Input

连续输入多组数据,每组数据的第一行是三个整数mu, nu, tu(tu <= 50),分别表示稀疏矩阵的行数、列数和矩阵中非零元素的个数,随后tu行输入稀疏矩阵的非零元素所在的行、列值和非零元素的值,同一行数据之间用空格间隔。(矩阵以行序为主序)

Output

输出转置后的稀疏矩阵的三元组顺序表表示。

Sample Input

3 5 5

1 2 14

1 5 -5

2 2 -7

3 1 36

3 4 28

Sample Output

1 3 36

2 1 14

2 2 -7

4 3 28

5 1 -5

Hint

Source

xam

首先补充下什么叫做稀疏矩阵:矩阵中非零元素的个数远远小于矩阵元素的总数,并且非零元素的分布没有规律,通常认为矩阵中非零元素的总数比上矩阵所有元素总数的值小于等于0.05时,则称该矩阵为稀疏矩阵(sparse matrix)。了解就可以跟题目没有一毛钱关系

这个题的数据量比较小只有50,所以可以用暴搜按顺序把矩阵逆置。也可是在输入的时候就按照(y,x)的顺序输入,然后排序。两种方法都能过,这后面的可以当成废话。前一种时间复杂度为(nu*tu),后一种视选择的排序方法而定,(tulogtu)到(tu)^2。讲真按数据范围来看,后一种快一些。

第一种方法。

#include <stdio.h>
#include <stdlib.h> struct node
{
int x,y,w;
}a[55],b[55]; int main()
{
int m,n,num,i,j,ans;
while(scanf("%d%d%d",&m,&n,&num)!=EOF)
{
ans = 0;
for(i=0;i<num;i++)
scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].w);
for(i=1;i<=n;i++)
{
for(j=0;j<num;j++)
{
if(a[j].y==i)
{
b[ans].x = i;
b[ans].y = a[j].x;
b[ans++].w = a[j].w;
}
}
}
for(i=0;i<num;i++)
printf("%d %d %d\n",b[i].x,b[i].y,b[i].w);
}
return 0;
}

第二种方法(这里用的是冒泡排序,复杂度n^2)

#include <stdio.h>
#include <stdlib.h> struct node
{
int x,y,w;
}a[55],t; int main()
{
int m,n,num,i,j;
while(scanf("%d%d%d",&m,&n,&num)!=EOF)
{
for(i=0;i<num;i++)
scanf("%d%d%d",&a[i].y,&a[i].x,&a[i].w);
for(i=0;i<num-1;i++)
{
for(j=0;j<num-i-1;j++)
{
if(a[j].x>a[j+1].x)
{
t = a[j];
a[j] = a[j+1];
a[j+1] = t;
}
else if(a[j].x==a[j+1].x)
{
if(a[j].y>a[j+1].y)
{
t = a[j];
a[j] = a[j+1];
a[j+1] = t;
}
}
}
}
for(i=0;i<num;i++)
printf("%d %d %d\n",a[i].x,a[i].y,a[i].w);
}
return 0;
}

SDUT-3347_数据结构实验之数组三:快速转置的更多相关文章

  1. SDUT 3347 数据结构实验之数组三:快速转置

    数据结构实验之数组三:快速转置 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 转置运算是一 ...

  2. SDUT OJ 数据结构实验之链表三:链表的逆置

    数据结构实验之链表三:链表的逆置 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descri ...

  3. SDUT 3311 数据结构实验之串三:KMP应用

    数据结构实验之串三:KMP应用 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 有n个小朋友 ...

  4. SDUT OJ 数据结构实验之二叉树三:统计叶子数

    数据结构实验之二叉树三:统计叶子数 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descr ...

  5. SDUT OJ 数据结构实验之串三:KMP应用

    数据结构实验之串三:KMP应用 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descrip ...

  6. SDUT OJ 数据结构实验之排序三:bucket sort

    数据结构实验之排序三:bucket sort Time Limit: 250 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem D ...

  7. SDUT 3400 数据结构实验之排序三:bucket sort

    数据结构实验之排序三:bucket sort Time Limit: 150MS Memory Limit: 65536KB Submit Statistic Problem Description ...

  8. SDUT 3375 数据结构实验之查找三:树的种类统计

    数据结构实验之查找三:树的种类统计 Time Limit: 400MS Memory Limit: 65536KB Submit Statistic Problem Description 随着卫星成 ...

  9. SDUT 3342 数据结构实验之二叉树三:统计叶子数

    数据结构实验之二叉树三:统计叶子数 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 已知二叉 ...

随机推荐

  1. TZ_07_SSM整合

    1.坐标版本控制: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www ...

  2. JS简单实现:根据奖品权重计算中奖概率实现抽奖的方法

    本文主要介绍:使用 JS 根据奖品权重计算中奖概率实现抽奖的方法. 一.示例场景 1.1.设置抽奖活动的奖项名称 奖项名称:["一等奖", "二等奖", &qu ...

  3. CesiumLab V1.3 新功能 MAX场景处理(免费Cesium处理工具集)

    每次到写文章的时候就很高兴,意味着又有重大功能更新了,也意味着10多天昏天黑地的闭关日子暂时结束了. 依照惯例,先放图   小范围精模型cesium加载效果   大范围白模cesium加载效果     ...

  4. ucore 物理内存探测 lab2 附录A&B

    探测物理内存分布的大小和方法 bootloader 增加的工作 bootasm.S 中对应了 probe_memory 到 finish_probe 的部分. 通过BIOS 中断 获取内存可调用参数为 ...

  5. Oracle JOB的建立,定时执行任务

    Oracle JOB的建立,定时执行任务 oracle job的相关设置 next date: 2010-12-28 18:05:00 interval: to_date(to_char(sysdat ...

  6. Codefroces 213E. Two Permutations

    E. Two Permutations time limit per test 3 seconds memory limit per test 256 megabytes input standard ...

  7. (转)Sql server中 如何用sql语句创建视图

    1.视图的作用 视图的作用: 第一点:使用视图,可以定制用户数据,聚焦特定的数据. 解释:     在实际过程中,公司有不同角色的工作人员,我们以销售公司为例的话,     采购人员,可以需要一些与其 ...

  8. 初探element+vue+vue-router

    基本步骤先准备好 npm install -g vue-cli npm init webpack cnpm i element-ui -S 修改/src/main.js // The Vue buil ...

  9. WCF 服务

    1.代码 using System; using System.Collections.Generic; using System.Linq; using System.Runtime.Seriali ...

  10. Google earth爬取卫星影像数据并进行标注路网的方法

    一.下载goole earth 和GetScreen: 试了很多,找了可以使用的上传到百度网盘,链接如下所示: 链接:https://pan.baidu.com/s/1fp-W8u68iRsJ0xcu ...