c语言处理矩阵,c语言程序设计矩阵运算

本文目录一览:

用C语言编写一个矩阵运算的程序,高分!

//矩阵三元组之矩阵相加 相乘

#include iostream

using namespace std;

typedef int Elemtype;

#define MAXSIZE 12500 //最大非零元素

typedef struct Triple

{

Elemtype value;

int row,col;

}Triple;

typedef struct TSMatrix

{

Triple data[MAXSIZE+1];

int mu,nu,tu;

}TSMatrix;

TSMatrix T;

void InputMatrix(TSMatrix T) //输入t个非零元素

{

cout”请输入稀疏矩阵的信息,(行,列,非零元素个数)”endl;

cinT.muT.nuT.tu;

int i;

cout”请输入非零元素的信息(行,列,值),提醒(下标从1开始)”endl;

for(i=1;i=T.tu;++i)

{

cinT.data[i].rowT.data[i].colT.data[i].value;

}

}

void Output(TSMatrix T)

{

cout”矩阵的三元组表示(ROW=)”T.mu” COL=”T.nu”非零个数=”T.tuendl;

int i;

for(i=1;i=T.tu;++i)

{

cout”ROW(行):”T.data[i].row” COL(列):”T.data[i].col” Value(值)”T.data[i].valueendl;

}

}

void TransposeSMatrix(TSMatrix M,TSMatrix T) //矩阵的转置

{

T.mu=M.nu;T.nu=M.mu;T.tu=M.tu;

int i,j,k=1;

for(i=1;i=M.nu;++i)

{

for(j=1;j=M.tu;++j)

if(M.data[j].col==i)

{

T.data[k].row=i;

T.data[k].col=M.data[j].row;

T.data[k].value=M.data[j].value;

++k;

}

}

}

void AddMastrix(TSMatrix M,TSMatrix T,TSMatrix Q) //矩阵相加

{

int index_a,index_b,i=1,j=1,k=1;

Q.mu=M.mu; Q.nu=M.nu;

while (i=M.tuj=T.tu)

{

index_a=(M.data[i].row)*(M.data[i].col)+M.data[i].col;

index_b=(T.data[j].row)*(T.data[j].col)+T.data[j].col;

if(index_aindex_b)

{

Q.data[k]=M.data[i];

i++;

k++;

}

else if(index_aindex_b)

{

Q.data[k]=T.data[j];

j++;

k++;

}

else if(index_a==index_b)

{

if((M.data[i].value+T.data[j].value)!=0)

{

Q.data[k]=M.data[i];

Q.data[k].value=M.data[i].value+T.data[j].value;

k++;

}

++i;

++j;

}

}

//复制剩余元素

for(;i=M.tu;++i)

{

Q.data[k]=M.data[i];

k++;

}

for(;j=T.tu;++j)

Q.data[k++]=T.data[j];

Q.tu=k-1;

}

void Multiply(TSMatrix M,TSMatrix T,TSMatrix Q) //相乘

{

if(M.nu!=T.mu)

{

cerr”两矩阵相乘不合法”endl;

return ;

}

int *rowSize=new int[T.mu+1]; //存放每行非零元素的个数

int *rowStart=new int[T.mu+2]; //矩阵每行在三元组开始位置

int *temp=new int[T.nu+1]; //存放结果矩阵中每行的计算结果

int i,Current,k,ROWM,COLM,COLB;

for(i=1;i=T.mu;i++) rowSize[i]=0;

for(i=1;i=T.tu;++i) rowSize[T.data[i].row]++;

rowStart[1]=1;

for(i=2;i=T.mu+1;i++)

rowStart[i]=rowStart[i-1]+rowSize[i-1];

Current=1; k=1;

while (Current=M.tu)

{

ROWM=M.data[Current].row; //当前三元组数据中元素的行号

for(i=1;i=T.nu;++i) temp[i]=0;

while (Current=M.tuROWM==M.data[Current].row)

{

COLM=M.data[Current].col; //当前元素的列号,方便与T矩阵的行号相乘

for(i=rowStart[COLM];irowStart[COLM+1];i++) //对应T矩阵中每行的个数

{

COLB=T.data[i].col;

temp[COLB]+=(M.data[Current].value)*(T.data[i].value);

}

Current++;

}

for(i=1;i=T.nu;i++)

{

if(temp[i]!=0)

{

Q.data[k].row=ROWM;

Q.data[k].col=i;

Q.data[k].value=temp[i];

}

k++;

}

}

Q.mu=M.mu;Q.nu=T.nu;

Q.tu=k-1;

}

int main()

{

TSMatrix T,M,Q,S;

InputMatrix(M);

InputMatrix(T);

cout”两矩阵相乘”endl;

Multiply(M,T,Q);

Output(Q);

cout”两矩阵相加”endl;

AddMastrix(M,M,S);

Output(S);

system(“pause”);

return 0;

}

C语言 关于矩阵?

方法1:直接定义10*10的数组,读取全部数据,再根据选择的行列数打印输出部分数据。

方法2:通过文件流指针的移动,跨过不需要的内容。(这里控制文件流指针可利用ftell和fseek函数来移动指定字节数)我是利用fscanf读取需要的内容,遇到需要跳行就用fgets来跳过。(注意常量参数根据自己需求修改)。

说明:边读取边打印输出,就不需要变量存储。我的代码是把读取出来的内容存放在三维数组中(文件内容你没指定,如是单纯数字,二维数组即可,我是作为字符串处理,故用三维数组。),数组是根据实际大小,动态申请,写成两个独立函数。

下面是代码:

#include stdio.h

#include string.h

#include malloc.h

#define MAXR 10//文件中矩阵最大行

#define MAXC 10//文件中矩阵最大列

#define MS 3//矩阵中元素字符串最大字符数(包含结束符号,不可小于实际内容)

#define MBUF 100//文件中一行最大字符数,可设置大一点

char ***getMem(int r,int c,int len);//动态申请一个三维数组

void freeMem(char ***datas,int r,int c);//释放数组空间

void showDatas(char ***datas,int r,int c);//打印输出结果

int main()

{

  int r=MAXR+1,c=MAXC+1,i=0,j=0;

  char ***datas=NULL,str[3],buf[MBUF];

  FILE *fp=NULL;

  printf(“请输入要获取的行数和列数:\n”);

  while(r0 || rMAXR || c0 || cMAXC)scanf(“%d%d”,r,c);

  datas=getMem(r,c,MS);

  fp=fopen(“C:\\test.data”,”r”);

  if(!fp) return 1;

  while(fscanf(fp,”%s”,str)!=-1)

  {

      if(ic) strcpy(datas[j][i],str),i++;

      if(i==c)

      {

          if(!fgets(buf,sizeof(buf),fp)) break;

          i=0,j++;

      }

      if(j==r) break;

  }

  showDatas(datas,r,c);

  freeMem(datas,r,c);

  return 0;

}

void showDatas(char ***datas,int r,int c)

{

  int i,j;

  for(i=0;ir;i++,printf(“\n”))

      for(j=0;jc;j++)

          printf(“%s “,datas[i][j]);

  printf(“\n”);

}

void freeMem(char ***datas,int r,int c)

{

  int i,j;

  if(!datas)

  {

      for(i=0;ir;i++,free(datas[i]))

          for(j=0;jc;j++)

              free(datas[i][j]);

      free(datas);

  }

}

char ***getMem(int r,int c,int len)

{

  int i,j;

  char ***datas=NULL,**dr=NULL;

  datas=(char ***)malloc(sizeof(char **)*r);

  if(!datas) return NULL;

  for(i=0;ir;i++)

  {

      dr=(char **)malloc(sizeof(char *)*c);

      if(!dr) return NULL;

      else

      {

          for(j=0;jc;j++)

          {

              dr[j]=(char *)malloc(sizeof(char)*len);

              if(!dr[j]) return NULL;

          }

          datas[i]=dr;

      }

  }

  return datas;

}

c语言矩阵运算

我在这儿给你提供一些思路:码程序交给你自己了!

0、提示输入4*4的实数矩阵,然后键盘依次输入实数矩阵中各元素;在屏幕上先用printf输出了4*4 矩阵的形式;

1、4*4的实数矩阵,那以为这定义一个float a[4][4]的4*4的二维矩阵或者float a[16]的一维矩阵;

2、求所有的元素中负数的个数,意思是把你把数组中每个数和0比较一遍,即循环16次,发现小于 0则把一个全局变量加1,就求出了所有的负数的个数!

3、二维数组循环通常用两个for循环完成,再找一个全局变量用于求元素之和的。一维数组的话更 简单

4、输出(2)、(3)就把那2个全局变量的值输出即可!

希望可以帮到你,如果满意请采纳!

其实你屏幕上显示的是4*4矩阵的形式是输入的,但是存储可以使用长度为16的一维数组,这样更加容易了!

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/282798.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-22 08:06
下一篇 2024-12-22 08:06

相关推荐

  • Python将矩阵存为CSV文件

    CSV文件是一种通用的文件格式,在统计学和计算机科学中非常常见,一些数据分析工具如Microsoft Excel,Google Sheets等都支持读取CSV文件。Python内置…

    编程 2025-04-29
  • AES加密解密算法的C语言实现

    AES(Advanced Encryption Standard)是一种对称加密算法,可用于对数据进行加密和解密。在本篇文章中,我们将介绍C语言中如何实现AES算法,并对实现过程进…

    编程 2025-04-29
  • 学习Python对学习C语言有帮助吗?

    Python和C语言是两种非常受欢迎的编程语言,在程序开发中都扮演着非常重要的角色。那么,学习Python对学习C语言有帮助吗?答案是肯定的。在本文中,我们将从多个角度探讨Pyth…

    编程 2025-04-29
  • Python被称为胶水语言

    Python作为一种跨平台的解释性高级语言,最大的特点是被称为”胶水语言”。 一、简单易学 Python的语法简单易学,更加人性化,这使得它成为了初学者的入…

    编程 2025-04-29
  • OpenJudge答案1.6的C语言实现

    本文将从多个方面详细阐述OpenJudge答案1.6在C语言中的实现方法,帮助初学者更好地学习和理解。 一、需求概述 OpenJudge答案1.6的要求是,输入两个整数a和b,输出…

    编程 2025-04-29
  • Python按位运算符和C语言

    本文将从多个方面详细阐述Python按位运算符和C语言的相关内容,并给出相应的代码示例。 一、概述 Python是一种动态的、面向对象的编程语言,其按位运算符是用于按位操作的运算符…

    编程 2025-04-29
  • Python双重循环输出矩阵

    本文将介绍如何使用Python双重循环输出矩阵,并从以下几个方面详细阐述。 一、生成矩阵 要输出矩阵,首先需要生成一个矩阵。我们可以使用Python中的列表(List)来实现。具体…

    编程 2025-04-29
  • 学堂云Python语言程序设计答案

    学堂云Python语言程序设计是一门重要的计算机专业课程。它涵盖了Python语言及其应用,包括基础语法、函数、文件处理、数据结构、图形界面和网络编程等内容。在学习中,我们经常会需…

    编程 2025-04-29
  • Python语言由荷兰人为中心的全能编程开发工程师

    Python语言是一种高级语言,很多编程开发工程师都喜欢使用Python语言进行开发。Python语言的创始人是荷兰人Guido van Rossum,他在1989年圣诞节期间开始…

    编程 2025-04-28
  • 二阶快速求逆矩阵

    快速求逆矩阵是数学中的一个重要问题,特别是对于线性代数中的矩阵求逆运算,如果使用普通的求逆矩阵方法,时间复杂度为O(n^3),计算量非常大。因此,在实际应用中需要使用更高效的算法。…

    编程 2025-04-28

发表回复

登录后才能评论