当前位置: 首页 > news >正文

[1007]魔法少女小Scarlet

#include<iostream>
#include<iomanip>
#include<cstring>
#include<sstream>
#include<algorithm>
using namespace std;
void fold(int x,int y,int r,int**a){//进行对折操作
    int R=r/2;
    int p=0;
    int b;
    for(int i=x-R;i<x;i++){
        for(int j=y-R;j<=y+R;j++){
            p=2*x-i;
            b=a[p][j];
            a[p][j]=a[i][j];
            a[i][j]=b;
        }
    }
}
void revolve_shun(int x,int y,int r,int**a){//顺时针
    int sum=0;
    int R=r/2;
    sum=x+y;
    int p,q;
    int b;
    for(int i=x-R;i<=x+R;i++){
        for(int j=y-R;j<=y+R;j++){
            if((i+j)>=sum){
                break;
            }
            if((i+j)<sum){
                p=x+(y-j);
                q=y+(x-i);
                b=a[p][q];
                a[p][q]=a[i][j];
                a[i][j]=b;
            }
            
        }
    }
}
void revolve_ni(int x,int y,int r,int**a){//逆时针
    int sum=0;
    int R=r/2;
    sum=y-x;
    int p,q;
    int b;
    for(int i=x+R;i>=x-R;i--){
        for(int j=y+R;j>=y-R;j--){
            if((j-i)<=sum){
                break;
            }
            if((j-i)>sum){
                p=x-(y-j);
                q=y-(x-i);
                b=a[p][q];
                a[p][q]=a[i][j];
                a[i][j]=b;
            }

        }
    }
}
int main(){
    int n,m;
    cin>>n>>m;
    int **a;
    a=new int*[n];
    for(int i=0;i<n;i++){
        a[i]=new int[n];
    }
    int t=1;
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            a[i][j]=t;
            t++;
        }
    }
    while(m>0){
        int x,y,r,z;
        cin>>x>>y>>r>>z;
        x--;
        y--;
        r=2*r+1;
        if(z==0){
            revolve_shun(x,y,r,a);
        }else{
            revolve_ni(x,y,r,a);
        }
        fold(x,y,r,a);
        m--;
    }
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            cout<<a[i][j]<<" ";
        }
        cout<<endl;
    }
    system("pause");
    return 0;
}
 

相关文章:

  • 广东建设工程信息网官网证书查询/seo工具在线访问
  • java做简易网站/seo排名点击软件运营
  • 免费采集器 wordpress/百度在线问答
  • 网站开发课题背景/线上营销活动方案
  • 烟台芝罘区住房建设局网站/查域名备案
  • 沧州手机网站建设/爱站数据
  • 点击试剂Methyltetrazine-PEG4-NHS ester,甲基四嗪-PEG4-琥珀酰亚胺酯,CAS:1802907-9
  • 【设计模式】设计模式
  • 详解C语言二级指针三种内存模型
  • python自学入门(打卡十二)2022-12-04
  • LTspice XVII > Transformer 变压器仿真
  • 17-JavaSE基础巩固练习:Math类API两道数学算法水题
  • [附源码]JAVA毕业设计课程答疑系统(系统+LW)
  • 7 8051 C51 使用_getkey对scanf输入重定向,实现标准输入输出,getchar
  • 逻辑回归模型和Python代码实现
  • Web 性能测试
  • 关于小程序session_key漏洞问题的解决2022-12-01
  • 基于MSER的高速公路交通标志提取matlab仿真