c++ 关于二维数组的问题

将3x3阶二维数组的关于主对角线对称的元素互换。二维数组的第1至3行元素分别为1、2、3、4、5、6、7、8、9。用矩阵形式分别输出互换前、后的数组元素值。... 将3x3阶二维数组的关于主对角线对称的元素互换。二维数组的第1至3行元素分别为1、2、3、4、5、6、7、8、9。用矩阵形式分别输出互换前、后的数组元素值。 展开
 我来答
seamaswong
2011-06-24 · TA获得超过1122个赞
知道小有建树答主
回答量:483
采纳率:0%
帮助的人:381万
展开全部
#include<iostream>
using namespace std;

#define ROW 3
#define COLUMN 3

void swap(int& a,int& b)
{
int temp=a;
a=b;
b=temp;
}

void main()
{
int a[ROW][COLUMN]={{1,2,3},{4,5,6},{7,8,9}};
cout<<"before swap:"<<endl;

for(int i=0;i<ROW;i++)
{
for(int j=0;j<COLUMN;j++)
{
cout<<a[i][j]<<" ";
}
cout<<endl;
}

for(int row=0;row<ROW;row++)
{
for(int col=0;col<COLUMN;col++)
{
if(col<row)
{
swap(a[row][col],a[col][row]);
}
}
}

cout<<"after swap:"<<endl;

for(int i=0;i<ROW;i++)
{
for(int j=0;j<COLUMN;j++)
{
cout<<a[i][j]<<" ";
}
cout<<endl;
}

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
250cfeoom
2011-06-24 · TA获得超过2557个赞
知道大有可为答主
回答量:4657
采纳率:71%
帮助的人:835万
展开全部
#include "stdafx.h"
#include "conio.h"
#include <iostream>
using namespace std;

void MatrixChain(int* p, int n, int m[7][7],int s[7][7])
{
for(int i=1;i<=n;i++)m[i][i]=0;
for(int r=2;r<=n;r++)
for(int i=1;i<=n-r+1;i++)
{
int j=i+r-1;
m[i][j]=m[i+1][j]+p[i-1]*p[i]*p[j];
s[i][j]=i;
for(int k=i+1;k<j;k++)
{
int t=m[i][k]+m[k+1][j]+p[i-1]*p[k]*p[j];
if(t<m[i][j])
}
}
}

void Traceback(int i,int j,int s[7][7])
{
if(i==j)return;
Traceback(i,s[i][j],s);
Traceback(s[i][j]+1,j,s);
cout<<"Multiply A"<<i<<","<<s[i][j];
cout<<"and A"<<(s[i][j]+1)<<","<<j<<endl;
}
int main()
{
int p[7]=;
int n=6;
int m[7][7];
int s[7][7];
MatrixChain(p,n,m,s);
Traceback(1,6,s);
getchar();
return 0;
}

你的**c指针不能用 new *c 指针可以new 所以出错 直接用数组就可以了
上面代码我编译过了 绝对可以通过啊。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
sun_siliang
推荐于2018-04-14 · TA获得超过2.6万个赞
知道大有可为答主
回答量:9913
采纳率:100%
帮助的人:4675万
展开全部
#include <stdio.h>

int main()
{
int i,j,t,a[3][3]={1,2,3,4,5,6,7,8,9};
printf("Before:\n");
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
printf("%d ",a[i][j]);
printf("\n");
}

for(i=1;i<3;i++)
for(j=0;j<i;j++)
{
t=a[i][j];
a[i][j]=a[j][i];
a[j][i]=t;
}

printf("After:\n");
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
printf("%d ",a[i][j]);
printf("\n");
}
return 0;
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式