PTA 1097-矩阵行平移

给定一个𝑛×𝑛n×n的整数矩阵。对任一给定的正整数𝑘<𝑛k<n,我们将矩阵的奇数行的元素整体向右依次平移1、......、𝑘、1、......、𝑘、......1、......、k、1、......、k、......个位置,平移空出的位置用整数𝑥x补。你需要计算出结果矩阵的每一列元素的和。

输入格式:

输入第一行给出 3 个正整数:𝑛(<100)、𝑘(<𝑛)、𝑥(<100)n(<100)、k(<n)、x(<100),分别如题面所述。

接下来𝑛n行,每行给出𝑛n个不超过 100 的正整数,为矩阵元素的值。数字间以空格分隔。

输出格式:

在一行中输出平移后第 1 到𝑛n列元素的和。数字间以 1 个空格分隔,行首尾不得有多余空格。

输入样例:

复制代码
7 2 99
11 87 23 67 20 75 89
37 94 27 91 63 50 11
44 38 50 26 40 26 24
73 85 63 28 62 18 68
15 83 27 97 88 25 43
23 78 98 20 30 81 99
77 36 48 59 25 34 22

Copy

输出样例:

复制代码
529 481 479 263 417 342 343

Copy

样例解读

需要平移的是第 1、3、5、7 行。给定 ,应该将这三列顺次整体向右平移 1、2、1、2 位(如果有更多行,就应该按照 1、2、1、2、1、2 ...... 这个规律顺次向右平移),左端的空位用 99 来填充。平移后的矩阵变成:

复制代码
99 11 87 23 67 20 75
37 94 27 91 63 50 11
99 99 44 38 50 26 40
73 85 63 28 62 18 68
99 15 83 27 97 88 25
23 78 98 20 30 81 99
99 99 77 36 48 59 25

代码:

cpp 复制代码
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
int main(){
    int n,k,x;
    cin>>n>>k>>x;
    int a[200][200],b[200][200];
    for(int i=0;i<n;++i){
        for(int j=0;j<n;++j){
            cin>>a[i][j];
        }
    } 
    int t=1;//移动个数
    int sum[10050]={0};
        for(int i=0;i<n;++i){
            if(i%2==0){
                int q;
                for(int j=0;j<t;++j){
                    b[i][j]=x;
                    q=j;
                }
                for(int j=0;j<n-t+1;++j){
                    b[i][++q]=a[i][j];
                }
               if(t<k)t++;//增加x个数
               else if(t==k)t=1;//到k个后变为1
            } 
            else{
                for(int j=0;j<n;++j){
                    b[i][j]=a[i][j];
                }
            }
        }
        //  for(int i=0;i<n;++i){
        //      for(int j=0;j<n;++j){
        //          cout<<b[i][j]<<" ";
        //      }cout<<endl;
        //  }
        for(int j=0;j<n;++j){
            for(int i=0;i<n;++i){
                sum[j]+=b[i][j];
            }
        }
        for(int i=0;i<n;++i){
            cout<<sum[i];
            if(i!=n-1)cout<<" ";
        }
return 0;
}
相关推荐
2601_957787583 小时前
矩阵运营的技术底座:为什么“一体化系统“正在取代“工具拼装“
人工智能·矩阵·矩阵运营
AI科技星6 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
feifeigo1238 小时前
STM32矩阵键盘驱动(库函数版)实现
stm32·矩阵·计算机外设
oo哦哦8 小时前
全域矩阵系统的技术架构拆解:从单点效率到链路闭环
人工智能·矩阵·架构
2601_957786779 小时前
拆解矩阵系统的底层逻辑:从“人海战术“到“一套系统管所有“
大数据·人工智能·矩阵
AI科技星10 小时前
第二章 平行素数对网格:矩形→等腰梯形拓扑变换(完整公理终稿)
c语言·开发语言·线性代数·算法·量子计算·agi
dog25010 小时前
解析几何的现代范式-算力,拟合与对偶
服务器·开发语言·网络·线性代数·php
晚霞的不甘11 小时前
CANN Catlass 矩阵乘模板库深度解析:高性能矩阵运算的进阶之路
人工智能·python·线性代数·矩阵
2601_9577867712 小时前
矩阵系统深度解析:从冷启动困局到智能化运营的技术演进
大数据·人工智能·矩阵
AI_yangxi12 小时前
短视频矩阵系统技术强的公司
线性代数·矩阵