一、实验目的
了解数组的两种存储表示方法,掌握数组在以行或列为主的存储结构中的地址计算方法
二、实验内容
1. 构建数组a[3][3]、b[3][3],求两个数组元素之和并保存到数组result[3][3]中。
2. 将数组a[3][3]按行序为主序转换到一维数组k[9]中存放。
1. #include "stdio.h" 2. #define M 3 3. void matrixadd(int m1[M][M],int m2[M][M],int result[M][M]) 4. { 5. int i,j; 6. for(i=0;i<M;i++) 7. { 8. for(j=0;j<M;j++) 9. result[i][j]=m1[i][j]+m2[i][j]; 10. } 11. } 12. void matrixtrams(int m1[M][M],int result[M*M]) 13. { 14. int i,j; 15. for(i=0;i<M;i++) 16. { 17. for(j=0;j<M;j++) 18. result[i*M+j]=m1[i][j]; 19. } 20. for(i=0;i<M*M;i++) 21. printf("%d ",result[i]); 22. printf("\n"); 23. } 24. void display(int result[M][M]) 25. { 26. int i,j; 27. printf("输出转换数值:\n"); 28. for(i=0;i<M;i++) 29. { 30. for(j=0;j<M;j++) 31. printf("%d ",result[i][j]); 32. printf("\n"); 33. } 34. } 35. main() 36. { 37. int a[M][M],b[M][M],result[M][M],k[M*M]; 38. int i,j; 39. printf("输入a数值为:\n"); 40. for(i=0;i<M;i++) 41. for(j=0;j<M;j++) 42. scanf("%d",&a[i][j]); 43. printf("输入b数值为:\n"); 44. for(i=0;i<M;i++) 45. for(j=0;j<M;j++) 46. scanf("%d",&b[i][j]); 47. matrixadd(a,b,result); 48. display(result); 49. matrixtrams(a,k); 50. }