《數(shù)據(jù)結構》課程設計報告--稀疏矩陣運算器_第1頁
已閱讀1頁,還剩21頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  數(shù)據(jù)結構</b></p><p><b>  課程設計報告</b></p><p>  設計題目:稀疏矩陣運算器</p><p>  班 級 計科112班 </p><p>  學 號

2、 </p><p>  姓 名 </p><p>  指導教師 </p><p>  起止時間 2013.10.14—2013.10.18 </p><p>  成 績

3、 </p><p>  2013—2014 年 一 學期</p><p><b>  一、實驗目的 </b></p><p>  通過實習,了解并初步掌握設計、實現(xiàn)較大系統(tǒng)的完整過程,包括系統(tǒng)分析、編碼設計、系統(tǒng)集成、以及調試分析,熟練掌握數(shù)據(jù)結構的選擇、設計、實現(xiàn)以及操作方法,為進一步的應

4、用開發(fā)打好基礎。</p><p><b>  問題描述</b></p><p>  稀疏矩陣是指那些多數(shù)元素為零的矩陣。利用“稀疏”特點進行存儲和計算可以大大節(jié)省存儲空間,提高計算效率。實現(xiàn)一個能進行稀疏矩陣基本運算的運算器。</p><p><b>  條件分析</b></p><p>  以“帶

5、行邏輯鏈接信息”的三元組順序表表示稀疏矩陣,實現(xiàn)矩陣轉置,求逆,實現(xiàn)兩個矩陣相加、相減和相乘的運算。稀疏矩陣的輸入形式采用三元組表示,而運算結果的矩陣則以通常的陣列形式列出。 </p><p>  演示程序以用戶和計算機的對話方式執(zhí)行,數(shù)組的建立方式為邊輸入邊建立。</p><p>  由題目要求可知:首先應輸入矩陣的行數(shù)和列數(shù),并判別給出的兩個矩陣的行、列數(shù)對于所要求作的運算是否相匹配。

6、</p><p>  程序可以對三元組的輸入順序不加以限制;根據(jù)對矩陣的行列,三元組作直接插入排序,從而進行運算時,不會產(chǎn)生錯誤。</p><p>  在用三元組表示稀疏矩陣時,相加、乘積和相減所得結果矩陣應該另生成;矩陣求逆時,為了算法方便,使用二維數(shù)組存放。 </p><p><b>  測試數(shù)據(jù)如下:</b></p><

7、;p>  10 0 0 0 0 0 10 0 0</p><p>  0 0 0 + 0 0 -1 = 0 0 8</p><p>  -1 0 0 1 0 -3 0 0 -3</p><p>  10 0 0 0 10 0<

8、;/p><p>  0 9 - 0 -1 = 0 10 </p><p>  -1 0 1 -3 -2 3</p><p>  1 0 0 1 0 1 0</p><p>  0 2 0 × 0 0

9、 = 0 0</p><p>  0 0 3 1 0 3 0</p><p><b>  概要設計</b></p><p>  抽象數(shù)據(jù)類型稀疏矩陣的定義如下:</p><p>  ADT SparseMatrix{</p><p>

10、;  數(shù)據(jù)對象:D={aij|i=1,2,…,m; j=1,2,…,n;</p><p>  aij∈ElemSet, m和n分別為矩陣的行數(shù)和列數(shù)}</p><p>  數(shù)據(jù)關系:R={Row,Colum }</p><p>  Row={﹤ai,j, ai,j+1﹥| 1≤i≤m, 1≤j≤n-1}</p><p>  Colum =

11、{﹤ai,j, ai+1,j﹥| 1≤i≤m-1, 1≤j≤n}</p><p><b>  基本操作:</b></p><p>  creat_matrix(crosslist TM)</p><p>  操作結果:創(chuàng)建稀疏矩陣矩陣TM</p><p>  print_matrix(crosslist TM)<

12、/p><p>  初始條件:稀疏矩陣TM存在</p><p>  操作結果:通常形式輸出稀疏矩陣</p><p>  add_matrix(crosslist A,crosslist B,crosslist &C) </p><p>  初始條件:稀疏矩陣A,B和C存在</p><p>  操作結果:稀疏矩陣

13、的加法運算:C=A+B</p><p>  sub_matrix(crosslist A,crosslist B,crosslist &C)</p><p>  初始條件:稀疏矩陣A,B和C存在</p><p>  操作結果:稀疏矩陣的減法運算:C=A-B</p><p>  multi_matrix(crosslist A,cros

14、slist B,crosslist &C)</p><p>  初始條件:稀疏矩陣A,B和C存在</p><p>  操作結果:稀疏矩陣的乘法運算:C=A×B </p><p>  }ADT SparseMatrix;</p><p><b>  2.主程序:</b></p><

15、;p>  void main( )</p><p><b>  {初始化;</b></p><p><b>  do {</b></p><p><b>  接受命令;</b></p><p><b>  選擇處理命令;</b></p>

16、<p><b>  }</b></p><p>  while(命令!=“退出”)</p><p>  3.本程序有四個模塊,調用關系如下:</p><p><b>  主程序模塊</b></p><p><b>  創(chuàng)建矩陣模塊</b></p>&l

17、t;p><b>  矩陣運算模塊</b></p><p><b>  矩陣輸出模塊</b></p><p><b>  程序設計</b></p><p><b>  1、矩陣的定義</b></p><p>  typedef struct list&

18、lt;/p><p>  { int row; </p><p>  int colum;</p><p>  int value; </p><p>  struct list *right;</p><p>  struct list *down;</p><p>  

19、}node,*element;</p><p>  typedef struct link</p><p>  { int row_size;//矩陣的行數(shù)</p><p>  int colum_size;//矩陣的列數(shù)</p><p>  int non_zero_amount;//非零元素的個數(shù)</p><p&

20、gt;  element *rhead;//行鏈表頭指針基址</p><p>  element *chead;//列鏈表頭指針基址</p><p>  }crosslist;</p><p>  2、基本操作設定為:</p><p>  稀疏矩陣的基本操作設置如下:</p><p>  int creat_matri

21、x(crosslist &one);//用十字鏈表創(chuàng)建稀疏矩陣</p><p>  int print_matrix(crosslist &one) //輸出稀疏矩陣</p><p>  int add_matrix(crosslist one,crosslist two,crosslist &three) //加法運算</p><

22、p>  int sub_matrix(crosslist M,crosslist N,crosslist &Q) //矩陣相減</p><p>  int multi_matrix(crosslist one,crosslist two,crosslist &three) //矩陣相乘</p><p>  int main(void) //主

23、函數(shù)</p><p><b>  函數(shù)的調用關系圖 </b></p><p><b>  六、測試結果 </b></p><p>  1.按題目測試要求輸入:</p><p><b>  (1)程序主頁面</b></p><p><b> 

24、?。?)矩陣相加</b></p><p><b>  (3)矩陣相減</b></p><p><b> ?。?)矩陣相乘</b></p><p><b>  (5)退出系統(tǒng)</b></p><p><b>  結果分析</b></p>

25、;<p>  本次作業(yè)中,稀疏矩陣在書本有較詳細的說明,給予了本次作業(yè)一個較大的幫助。</p><p>  整個程序主要運用了矩陣運算的規(guī)則,利用創(chuàng)建矩陣,分析數(shù)據(jù),行列是否匹配,矩陣運算,矩陣輸出。</p><p>  整個程序運行期間不是實行動態(tài)存儲管理,故占用空間比較大;特別是執(zhí)行稀疏矩陣的求逆過程。</p><p>  主要算法的時空分析:&l

26、t;/p><p>  加法,減法和乘法時間復雜度為:O(m×n)。</p><p><b>  參考資料</b></p><p>  《數(shù)據(jù)結構》(C語言版)——清華大學出版社; 作者: 嚴蔚敏、吳偉民;</p><p>  《數(shù)據(jù)結構題集》(C語言版)——清華大學出版社; 作者: 嚴蔚敏、吳偉民、米寧

27、</p><p>  《程序設計題典》(C語言版)——清華大學出版社; 作者: 李春葆</p><p><b>  附源程序:</b></p><p>  //用十字鏈表創(chuàng)建稀疏矩陣,求矩陣的加,減,乘,并且矩陣的輸入輸出都以常規(guī)矩陣形式</p><p>  #include <stdio.h></p

28、><p>  #include <stdlib.h></p><p>  #include <assert.h></p><p>  #include <windows.h></p><p>  #define OVERFLOW -1</p><p>  #define OK 1

29、</p><p>  #define ERROR 0</p><p>  typedef struct list</p><p>  { int row; </p><p>  int colum;</p><p>  int value; </p><p>  s

30、truct list *right;</p><p>  struct list *down;</p><p>  }node,*element;</p><p>  typedef struct link</p><p>  { int row_size; //矩陣的行數(shù)</p><p>

31、;  int colum_size; //矩陣的列數(shù)</p><p>  int non_zero_amount; //非零元素的個數(shù)</p><p>  element *rhead; //行鏈表頭指針基址</p><p>  element *chead; //列鏈表頭指針基址</p><p>  }

32、crosslist;</p><p>  int init_matrix(crosslist &one) //矩陣的初始化 </p><p><b>  {</b></p><p>  one.row_size=0;</p><p>  one.colum_size=0;

33、 </p><p>  one.non_zero_amount=0;</p><p>  one.rhead=NULL;</p><p>  one.chead=NULL;</p><p>  return OK;

34、 </p><p><b>  }</b></p><p>  int crea

35、t_matrix(crosslist &one) //用十字鏈表創(chuàng)建稀疏矩陣 </p><p><b>  {</b></p><p>  int m,n,t,i,j,k,a;</p><p>  element p,q;</p><p>  if(one.rhead)</p><

36、p><b>  {</b></p><p>  one.rhead=NULL;</p><p>  one.chead=NULL;</p><p>  one.row_size=0;</p><p>  one.colum_size=0;</p><p>  one.non_zero_amo

37、unt=0;</p><p><b>  }</b></p><p>  printf("\n請輸入稀疏矩陣的行數(shù) 列數(shù) 非零元個數(shù):");</p><p>  scanf("%d %d %d",&m,&n,&t);</p><p>  one.row_

38、size=m;</p><p>  one.colum_size=n;</p><p>  one.non_zero_amount=t;</p><p>  if(!(one.rhead=(element *)malloc((m+1)*sizeof(element))))exit(OVERFLOW); //分配單元</p><p>  

39、if(!(one.chead=(element *)malloc((n+1)*sizeof(element))))exit(OVERFLOW);</p><p>  for(i=1;i<=one.row_size+1;i++)</p><p><b>  {</b></p><p>  one.rhead[i]=NULL;</p&g

40、t;<p><b>  }</b></p><p>  for(i=1;i<=one.colum_size+1;i++)</p><p><b>  {</b></p><p>  one.chead[i]=NULL; </p><p><b>  }</

41、b></p><p>  for(k=1;k<=one.non_zero_amount;k++)</p><p><b>  {</b></p><p>  printf("\n請輸入第%d個非零元的行號 列號 非零元素值:",k);</p><p>  scanf("%d %d

42、 %d",&i,&j,&a);</p><p>  if(!(p=(list *)malloc(sizeof(list))))exit(OVERFLOW);</p><p><b>  p->row=i;</b></p><p>  p->colum=j;</p><p> 

43、 p->value=a; // 生成結點</p><p>  if(one.rhead[i]==NULL||one.rhead[i]->colum>j)</p><p><b>  {</b></p><p>  p->right=one.rhead[i]; </p><p>

44、;  one.rhead[i]=p;</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  for(q=one.rhead[i];(q->right)&&q->

45、;right->colum<j;q=q->right);</p><p>  p->right=q->right;</p><p>  q->right=p; //尋找在行中的插入位置</p><p><b>  }</b></p><p>  if(one.chead[j

46、]==NULL||one.chead[j]->row>i)</p><p><b>  {</b></p><p>  p->down=one.chead[j];</p><p>  one.chead[j]=p;</p><p><b>  }</b></p>&l

47、t;p><b>  else</b></p><p><b>  {</b></p><p>  for(q=one.chead[j];(q->down)&&q->down->row<i;q=q->down);</p><p>  p->down=q->dow

48、n;</p><p>  q->down=p; //尋找在列中的插入位置</p><p><b>  }</b></p><p><b>  }</b></p><p>  return(0);</p><p>  }//輸出十字鏈表的函數(shù) </p>

49、;<p>  int print_matrix(crosslist &one) //打印出稀疏矩陣</p><p><b>  {</b></p><p><b>  int i,j;</b></p><p><b>  int b=0;</b></p>

50、<p>  element p;</p><p>  for(i=1;i<=one.row_size;i++)</p><p><b>  {</b></p><p>  p=one.rhead[i];</p><p>  printf("\t\t\t\t ");</p>

51、;<p>  for(j=1;j<=one.colum_size;j++)</p><p><b>  { </b></p><p>  if(p!=NULL)</p><p><b>  {</b></p><p>  if(j==p->colum)</p&g

52、t;<p><b>  {</b></p><p>  printf("%4d",p->value );</p><p>  p=p->right;</p><p><b>  }</b></p><p><b>  else</b>

53、;</p><p>  printf("%4d",b);</p><p><b>  }</b></p><p><b>  else</b></p><p>  printf("%4d",b);</p><p><b>  

54、}</b></p><p>  printf(" \n");</p><p><b>  }</b></p><p>  return(0);</p><p><b>  }</b></p><p>  int add_matrix(cross

55、list one,crosslist two,crosslist &three) //加法運算</p><p><b>  {</b></p><p>  /*兩個矩陣相加*/</p><p>  assert(one.row_size==two.row_size&&one.colum_size==two.col

56、um_size);</p><p>  int i,j; //作為計數(shù)的循環(huán)</p><p>  element insert; //結點插入</p><p>  element pone,ptwo;</p><p>  element prow;

57、 //行的最后一個結點</p><p>  element *pcolum; //行列的最后一個結點</p><p>  three.row_size=one.row_size;</p><p>  three.colum_size=one.colum_size;</p><p>  t

58、hree.non_zero_amount=0;</p><p>  three.rhead=(element*)malloc(sizeof(element)*(three.row_size+1));</p><p>  assert(three.rhead!=NULL);</p><p>  three.chead=(element*)malloc(sizeof(e

59、lement)*(three.colum_size+1));</p><p>  assert(three.chead!=NULL);</p><p>  pcolum=(element*)malloc(sizeof(element)*(three.colum_size+1));</p><p>  assert(pcolum!=NULL);</p>

60、<p>  for(i=1;i<=three.row_size;i++)</p><p>  three.rhead[i]=NULL;</p><p>  for(i=1;i<=three.colum_size;i++)</p><p>  three.chead[i]=NULL;</p><p>  for(i=1;i

61、<=three.colum_size;i++)</p><p>  pcolum[i]=NULL;</p><p>  /*給相加后的結果排序*/</p><p>  for(i=1;i<=one.row_size;i++)</p><p><b>  {</b></p><p>  

62、pone=one.rhead[i];</p><p>  ptwo=two.rhead[i]; </p><p>  while(pone!=NULL&&ptwo!=NULL)</p><p>  {//both have nodes in the same row</p><p>  if(pone->colum

63、<ptwo->colum) //第一個矩陣的列數(shù)較小</p><p><b>  {</b></p><p>  insert=(element)malloc(sizeof(node));</p><p>  assert(insert!=NULL);</p><p>  insert->r

64、ow=i;</p><p>  insert->colum=pone->colum;</p><p>  insert->value=pone->value;</p><p>  insert->right=NULL;</p><p>  pone=pone->right;</p><p

65、>  three.non_zero_amount++;</p><p><b>  }</b></p><p><b>  else </b></p><p>  if(pone->colum>ptwo->colum) //第二個矩陣的列數(shù)較小 </p><p><

66、;b>  {</b></p><p>  insert=(element)malloc(sizeof(node));</p><p>  assert(insert!=NULL);</p><p>  insert->row=i;</p><p>  insert->colum=ptwo->colum;&l

67、t;/p><p>  insert->value=ptwo->value;</p><p>  insert->right=NULL;</p><p>  ptwo=ptwo->right;</p><p>  three.non_zero_amount++;</p><p><b>  

68、}</b></p><p><b>  else</b></p><p>  if(pone->value+ptwo->value!=0)//相加后的結果是非零元素</p><p><b>  {</b></p><p>  insert=(element)malloc(si

69、zeof(node));</p><p>  assert(insert!=NULL);</p><p>  insert->row=i;</p><p>  insert->colum=ptwo->colum;</p><p>  insert->value=pone->value+ptwo->value

70、;</p><p>  insert->right=NULL;</p><p>  pone=pone->right;</p><p>  ptwo=ptwo->right;</p><p>  three.non_zero_amount++;</p><p><b>  }</b&g

71、t;</p><p>  else //相加結果是零</p><p><b>  {</b></p><p>  pone=pone->right;</p><p>  ptwo=ptwo->right;</p><p><

72、b>  continue;</b></p><p><b>  }</b></p><p>  if(three.rhead[i]==NULL)</p><p>  three.rhead[i]=prow=insert;</p><p><b>  else</b></p&g

73、t;<p><b>  {</b></p><p>  prow->right=insert;</p><p>  prow=insert;</p><p><b>  }</b></p><p>  if(three.chead[insert->colum]==NULL)

74、</p><p>  three.chead[insert->colum]=pcolum[insert->colum]=insert;</p><p><b>  else</b></p><p><b>  {</b></p><p>  pcolum[insert->colum

75、]->down=insert;</p><p>  pcolum[insert->colum]=insert;</p><p><b>  }</b></p><p><b>  }</b></p><p>  while(pone!=NULL) </p><p&

76、gt;<b>  {</b></p><p>  insert=(element)malloc(sizeof(node));</p><p>  assert(insert!=NULL);</p><p>  insert->row=i;</p><p>  insert->colum=pone->co

77、lum;</p><p>  insert->value=pone->value;</p><p>  insert->right=NULL;</p><p>  pone=pone->right; </p><p>  three.non_zero_amount++;&l

78、t;/p><p>  if(three.rhead[i]==NULL)</p><p>  three.rhead[i]=prow=insert;</p><p><b>  else</b></p><p><b>  {</b></p><p>  prow->righ

79、t=insert;</p><p>  prow=insert;</p><p><b>  }</b></p><p>  if(three.chead[insert->colum]==NULL)</p><p>  three.chead[insert->colum]=pcolum[insert->

80、colum]=insert;</p><p><b>  else</b></p><p><b>  {</b></p><p>  pcolum[insert->colum]->down=insert;</p><p>  pcolum[insert->colum]=inser

81、t;</p><p><b>  }</b></p><p><b>  }</b></p><p>  while(ptwo!=NULL)</p><p><b>  {</b></p><p>  insert=(element)malloc(siz

82、eof(node));</p><p>  assert(insert!=NULL);</p><p>  insert->row=i;</p><p>  insert->colum=ptwo->colum;</p><p>  insert->value=ptwo->value;</p><

83、;p>  insert->right=NULL;</p><p>  ptwo=ptwo->right; </p><p>  three.non_zero_amount++;</p><p>  if(three.rhead[i]==NULL)</p><p>  three.r

84、head[i]=prow=insert;</p><p><b>  else</b></p><p><b>  {</b></p><p>  prow->right=insert;</p><p>  prow=insert;</p><p><b> 

85、 }</b></p><p>  if(three.chead[insert->colum]==NULL)</p><p>  three.chead[insert->colum]=pcolum[insert->colum]=insert;</p><p><b>  else</b></p><

86、;p><b>  {</b></p><p>  pcolum[insert->colum]->down=insert;</p><p>  pcolum[insert->colum]=insert;</p><p><b>  }</b></p><p><b>

87、  } </b></p><p><b>  }</b></p><p>  three.non_zero_amount=three.non_zero_amount;</p><p>  for(j=1;j<=three.colum_size;j++)</p><p>  {

88、 if(pcolum[j]!=NULL)</p><p>  pcolum[j]->down=NULL;</p><p><b>  }</b></p><p>  free(pcolum);</p><p>  return OK;</p><p><b>

89、  }//矩陣相加結束</b></p><p>  int sub_matrix(crosslist M,crosslist N,crosslist &Q) //矩陣相減</p><p>  { // 初始條件: 稀疏矩陣M與N的行數(shù)和列數(shù)對應相等</p><p>  /

90、/ 操作結果: 求稀疏矩陣的差Q=M-N </p><p><b>  int i,k;</b></p><p>  element p,pq,pm,pn;</p><p>  element *col;</p><p>  if(M.row_size!=N.row_size||M.colum_size!=N.colum

91、_size)</p><p><b>  {</b></p><p>  printf("兩個矩陣不是同類型的,不能相減\n");</p><p>  exit(OVERFLOW);</p><p><b>  }</b></p><p>  Q.row_

92、size=M.row_size; // 初始化Q矩陣 </p><p>  Q.colum_size=M.colum_size;</p><p>  Q.non_zero_amount=0; //元素個數(shù)的初值 </p><p>  Q.rhead=(element*)mall

93、oc((Q.row_size+1)*sizeof(element));</p><p>  if(!Q.rhead)</p><p>  exit(OVERFLOW);</p><p>  Q.chead=(element*)malloc((Q.colum_size+1)*sizeof(element));</p><p>  if(!Q.c

94、head)</p><p>  exit(OVERFLOW);</p><p>  for(k=1;k<=Q.row_size;k++) //初始化Q的行頭指針向量;各行鏈表為空鏈表</p><p>  Q.rhead[k]=NULL;</p><p>  for(k=1;k<=Q.colum_size;k++

95、) //初始化Q的列頭指針向量;各列鏈表為空鏈表 </p><p>  Q.chead[k]=NULL;</p><p>  col=(element*)malloc((Q.colum_size+1)*sizeof(element)); // 生成指向列的最后結點的數(shù)組 </p><p><b>  if(!col)</b>

96、;</p><p>  exit(OVERFLOW);</p><p>  for(k=1;k<=Q.colum_size;k++) // 賦初值 </p><p>  col[k]=NULL;</p><p>  for(i=1;i<=M.row_size;i++) //按行的順序相減 &l

97、t;/p><p><b>  {</b></p><p>  pm=M.rhead[i]; // pm指向矩陣M的第i行的第1個結點 </p><p>  pn=N.rhead[i]; // pn指向矩陣N的第i行的第1個結點 </p><p>  while(pm&a

98、mp;&pn) // pm和pn均不空 </p><p><b>  {</b></p><p>  if(pm->colum<pn->colum) // 矩陣M當前結點的列小于矩陣N當前結點的列 </p><p><b>  {</b></p&

99、gt;<p>  p=(element)malloc(sizeof(list)); // 生成矩陣Q的結點 </p><p><b>  if(!p)</b></p><p>  exit(OVERFLOW);</p><p>  Q.non_zero_amount++; // 非零元素數(shù)加&

100、lt;/p><p>  p->row=i; // 給結點賦值 </p><p>  p->colum=pm->colum;</p><p>  p->value=pm->value;</p><p>  p->right=NULL;</p><p>  

101、pm=pm->right; // pm指針向右移</p><p><b>  }</b></p><p>  else if(pm->colum>pn->colum) // 矩陣M當前結點的列大于矩陣N當前結點的列</p><p><b>  {</b>&

102、lt;/p><p>  p=(element)malloc(sizeof(list)); // 生成矩陣Q的結點 </p><p><b>  if(!p)</b></p><p>  exit(OVERFLOW);</p><p>  Q.non_zero_amount++; // 非零元素

103、數(shù)加1</p><p>  p->row=i; // 給結點賦值 </p><p>  p->colum=pn->colum;</p><p>  p->value=-pn->value;</p><p>  p->right=NULL;</p><p>

104、  pn=pn->right; // pn指針向右移 </p><p><b>  }</b></p><p>  else if(pm->value-pn->value) //矩陣M、N當前結點的列相等且兩元素之差不為0</p><p><b>  {</b></

105、p><p>  p=(element)malloc(sizeof(list)); // 生成矩陣Q的結點 </p><p><b>  if(!p)</b></p><p>  exit(OVERFLOW);</p><p>  Q.non_zero_amount++; // 非零元素數(shù)

106、加1</p><p>  p->row=i; // 給結點賦值 </p><p>  p->colum=pn->colum;</p><p>  p->value=pm->value-pn->value;</p><p>  p->right=NULL;</p&

107、gt;<p>  pm=pm->right; // pm指針向右移 </p><p>  pn=pn->right; // pn指針向右移</p><p><b>  }</b></p><p>  else // 矩陣M、N當前結

108、點的列相等且兩元素之差為0</p><p><b>  {</b></p><p>  pm=pm->right; // pm指針向右移 </p><p>  pn=pn->right; // pn指針向右移 </p><p><b>  continue;<

109、/b></p><p><b>  }</b></p><p>  if(Q.rhead[i]==NULL) // p為該行的第1個結點</p><p>  Q.rhead[i]=pq=p; // p插在該行的表頭且pq指向p(該行的最后一個結點)</p><p>  else

110、// 插在pq所指結點之后 </p><p><b>  {</b></p><p>  pq->right=p; // 完成行插入 </p><p>  pq=pq->right; // pq指向該行的最后一個結點</p><

111、;p><b>  }</b></p><p>  if(Q.chead[p->colum]==NULL) //p為該列的第1個結點 </p><p>  Q.chead[p->colum]=col[p->colum]=p; // p插在該列的表頭且col[p->j]指向p </p><

112、p>  else // 插在col[p->]所指結點之后 </p><p><b>  {</b></p><p>  col[p->colum]->down=p; // 完成列插入 </p><p>  col[p->

113、colum]=col[p->colum]->down; // col[p->j]指向該列的最后一個結點</p><p><b>  }</b></p><p><b>  }</b></p><p>  while(pm) // 將矩陣M該行的剩

114、余元素插入矩陣Q </p><p><b>  {</b></p><p>  p=(element)malloc(sizeof(list)); // 生成矩陣Q的結點 </p><p><b>  if(!p)</b></p><p>  exit(OVERFLOW);</p>&l

115、t;p>  Q.non_zero_amount++; // 非零元素數(shù)加1</p><p>  p->row=i; // 給結點賦值 </p><p>  p->colum=pm->colum;</p><p>  p->value=pm->value;&l

116、t;/p><p>  p->right=NULL;</p><p>  pm=pm->right; // pm指針向右移 </p><p>  if(Q.rhead[i]==NULL) // p為該行的第1個結點</p><p>  Q.rhead[i]=pq=p; // p插在該行的表頭且p

117、q指向p(該行的最后一個結點)</p><p>  else // 插在pq所指結點之后 </p><p><b>  {</b></p><p>  pq->right=p; // 完成行插入</p><p&g

118、t;  pq=pq->right; // pq指向該行的最后一個結點</p><p><b>  }</b></p><p>  if(Q.chead[p->colum]==NULL) // p為該列的第1個結點 </p><p>  Q.chead[p->colum

119、]=col[p->colum]=p; // p插在該列的表頭且col[p->j]指向p</p><p>  else // 插在col[p->j]所指結點之后 </p><p><b>  {</b></p><p>  col[p->colum]-&g

120、t;down=p; // 完成列插入 </p><p>  col[p->colum]=col[p->colum]->down; //col[p->j]指向該列的最后一個結點 </p><p><b>  }</b></p><p><b>  }</b></p&g

121、t;<p>  while(pn) // 將矩陣N該行的剩余元素插入矩陣Q </p><p><b>  {</b></p><p>  p=(element)malloc(sizeof(list)); // 生成矩陣Q的結點 </p><p><b>  if(!p)

122、</b></p><p>  exit(OVERFLOW);</p><p>  Q.non_zero_amount++; // 非零元素數(shù)加1</p><p>  p->row=i; // 給結點賦值 </p><p>  p->col

123、um=pn->colum;</p><p>  p->value=-pn->value;</p><p>  p->right=NULL;</p><p>  pn=pn->right; // pm指針向右移</p><p>  if(Q.rhead[i]==NULL) /

124、/ p為該行的第1個結點</p><p>  Q.rhead[i]=pq=p; // p插在該行的表頭且pq指向p(該行的最后一個結點) </p><p>  else //插在pq所指結點之后</p><p><b>  {</b></p><p>  pq->

125、;right=p; //完成行插入 </p><p>  pq=pq->right; // pq指向該行的最后一個結點 </p><p><b>  }</b></p><p>  if(Q.chead[p->colum]==NULL) // p為該列的第1個結點 </

126、p><p>  Q.chead[p->colum]=col[p->colum]=p; // p插在該列的表頭且col[p->j]指向p </p><p>  else // 插在col[p->j]所指結點之后 </p><p><b>  {</b>

127、;</p><p>  col[p->colum]->down=p; // 完成列插入 </p><p>  col[p->colum]=col[p->colum]->down; // col[p->j]指向該列的最后一個結點 </p><p><b>  }</b></p

128、><p><b>  }</b></p><p><b>  }</b></p><p>  for(k=1;k<=Q.colum_size;k++)</p><p>  if(col[k]) // k列有結點 </p><p>

129、  col[k]->down=NULL; // 令該列最后一個結點的down指針為空 </p><p>  free(col);</p><p>  return OK;</p><p><b>  }</b></p><p>  int multi_matrix(crosslist one,

130、crosslist two,crosslist &three) //矩陣相乘</p><p><b>  {</b></p><p>  /*把兩個矩陣相乘*/</p><p>  assert(one.colum_size==two.row_size);</p><p>  int i,j;//as

131、count in the loop</p><p>  int value;//temp total value</p><p>  element insert;//the node to insert into three</p><p>  element pone,ptwo;//use in traverse the node in one and two&

132、lt;/p><p>  element prow,pcolum;//mark the last row and colum node</p><p>  /*assignment*/</p><p>  three.row_size=one.row_size;</p><p>  three.colum_size=two.colum_size;&

133、lt;/p><p>  three.non_zero_amount=0; </p><p>  /*allocate memroy*/</p><p>  three.rhead=(element*)malloc(sizeof(element)*(three.row_size+1));</p><p>  assert(thre

134、e.rhead!=NULL);</p><p>  three.chead=(element*)malloc(sizeof(element)*(three.colum_size+1));</p><p>  assert(three.chead!=NULL); </p><p>  /*initialization*/</p><p&

135、gt;  for(i=1;i<=three.row_size;i++)</p><p>  three.rhead[i]=NULL;</p><p>  for(i=1;i<=three.colum_size;i++)</p><p>  three.chead[i]=NULL; </p><p><b>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論