C语言实现矩阵逆时针旋转90度,代码调试!!!!

先分别输入矩阵的行和列,再依次给矩阵赋值,要求矩阵逆时针旋转90°后输出。举例如下:输入:34123412341234输出:444333222111不要重新写代码!!!!... 先分别输入矩阵的行和列,再依次给矩阵赋值,要求矩阵逆时针旋转90°后输出。举例如下:
输入:3 4
1 2 3 4
1 2 3 4
1 2 3 4
输出:
4 4 4
3 3 3
2 2 2
1 1 1

不要重新写代码!!!!麻烦帮我看下我的错在哪里,为什么总是会意外停止?帮助我把下面的改正过来就可以,原因希望讲的详细一些,谢谢!!

以下是我的代码,麻烦帮我看下

#include <stdio.h>
#include <stdlib.h>
#define M 1000

void Rotation(int **a,int m,int n)
{
int tem[n][m];
int i,j,k = 0;

for(j=n-1;j>=0;j--)
{
for(i=0;i<m;i++)
tem[k][i] = a[i][j];
k++;
}

for(i=0;i<n;i++)
for(j=0;j<m;j++)
a[i][j] = tem[i][j];
}

int main()
{
int m,n;
int i,j;
int a[M][M];

scanf("%d %d",&m,&n);

for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);

Rotation(a,m,n);

for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
printf("%d ",a[i][j]);
printf("\n");
}

return 0;
}

使用的IDE是CodeBlocks.
展开
 我来答
KummerWu
推荐于2017-09-16 · TA获得超过694个赞
知道小有建树答主
回答量:378
采纳率:0%
帮助的人:420万
展开全部
  1. 局部变量数组a太大了,

    方法1:要么把M改小,

#include <stdio.h>

#include <stdlib.h>

#define M 100


void Rotation(int a[M][M],int m,int n)

{

    int tem[M][M];

    int i,j,k = 0;


    for(j=n-1;j>=0;j--)

    {

        for(i=0;i<m;i++)

            tem[k][i] = a[i][j];

        k++;

    }


for(i=0;i<n;i++)

        for(j=0;j<m;j++)

            a[i][j] = tem[i][j];

}


int main()

{

    int m,n;

    int i,j;

    int a[M][M];


    scanf("%d %d",&m,&n);


    for(i=0;i<m;i++)

        for(j=0;j<n;j++)

        scanf("%d",&a[i][j]);


    Rotation(a,m,n);


    for(i=0;i<n;i++)

    {

        for(j=0;j<m;j++)

            printf("%d ",a[i][j]);

        printf("\n");

    }


    return 0;

}

====================================================

2. 方法2:

要么把a和tem改为全局变量

#define M 1000


int tem[M][M];

void Rotation(int a[M][M],int m,int n)

{

    

    int i,j,k = 0;


    for(j=n-1;j>=0;j--)

    {

        for(i=0;i<m;i++)

            tem[k][i] = a[i][j];

        k++;

    }


for(i=0;i<n;i++)

        for(j=0;j<m;j++)

            a[i][j] = tem[i][j];

}

int a[M][M];

int main()

{

    int m,n;

    int i,j;

    


    scanf("%d %d",&m,&n);


    for(i=0;i<m;i++)

        for(j=0;j<n;j++)

        scanf("%d",&a[i][j]);


    Rotation(a,m,n);


    for(i=0;i<n;i++)

    {

        for(j=0;j<m;j++)

            printf("%d ",a[i][j]);

        printf("\n");

    }


    return 0;

}

追问
非常感谢您的回答,但有两个问题还想请教你,M值较大为什么会引起程序终止?还有为什么把a和tem改为全局变量,就又能解决M值较大的问题?还麻烦你简单说一说,以及关于这方面讲解比较全面的参考书什么的?而且编译器不是也允许定义这么大的数组么?如果将M减小到100,子函数中的第一个形参用二级指针的话,还是会出问题,这里也不知道为什么?谢谢你,一定采纳!
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式