北邮:C翻转

本文介绍了一个涉及矩阵旋转的编程挑战,详细解析了如何根据不同的指令旋转矩阵中的元素,并提供了完整的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这题神坑,我已遍体鳞伤,不想多解释。

输入描述:

输入有多组数据。
每组输入一个5 * 5的数组,然后输入一行,这一行有四个数,前两个代表操作类型,后两个数x y代表需操作数据为以坐标(x,y)为左上角的那几个数据。

输出描述:

输出翻转后的数组。
示例1

输入

1 2 3 4 5
6 7 8 9 10
11 12 13 14 15
16 17 18 19 20
21 22 23 24 25
1 3 1 1

输出

11 6 1 4 5
12 7 2 9 10
13 8 3 14 15
16 17 18 19 20
21 22 23 24 25
#include <bits/stdc++.h>
using namespace std;

void f(int a[][5],int x,int y,int len,int flag)
{
    int i,j,t[5][5],u,v;
    if(flag==0)//顺时针
    {
        for(i=y,u=0;i<=y+len-1;i++,u++)
            for(j=x+len-1,v=0;j>=x;j--,v++)
                t[u][v]=a[j][i];
        for(i=x,u=0;i<=x+len-1;i++,u++)
            for(j=y,v=0;j<=y+len-1;j++,v++)
                a[i][j]=t[u][v];
    }
    else//逆时针
    {
        for(i=y+len-1,u=0;i>=y;i--,u++)
            for(j=x,v=0;j<=x+len-1;j++,v++)
                t[u][v]=a[j][i];
        for(i=x,u=0;i<=x+len-1;i++,u++)
            for(j=y,v=0;j<=y+len-1;j++,v++)
                a[i][j]=t[u][v];
    }
}

int main()
{
    int i,j,n,a[5][5],b[4];
    while(scanf("%d%d%d%d%d",&a[0][0],&a[0][1],&a[0][2],&a[0][3],&a[0][4])!=EOF)
    {
        for(i=1;i<5;i++)
            for(j=0;j<5;j++)
                cin>>a[i][j];
        for(i=0;i<4;i++)
            cin>>b[i];
        if(b[0]==1&&b[1]==2)
            f(a,b[2]-1,b[3]-1,2,0);
        if(b[0]==1&&b[1]==3)
            f(a,b[2]-1,b[3]-1,3,0);
        if(b[0]==2&&b[1]==2)
            f(a,b[2]-1,b[3]-1,2,1);
        if(b[0]==2&&b[1]==3)
            f(a,b[2]-1,b[3]-1,3,1);
        for(i=0;i<5;i++)
        {
            for(j=0;j<4;j++)
                cout<<a[i][j]<<" ";
            cout<<a[i][4]<<endl;
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值