接下来 n 行,每行给出 n 个不超过 100 的正整数,为矩阵元素的值。数字间以空格分隔。
输出格式:
在一行中输出平移后第 1 到 n 列元素的和。数字间以 1 个空格分隔,行首尾不得有多余空格。
输入样例:
输出样例:
529 481 479 263 417 342 343
样例解读
需要平移的是第 1、3、5、7 行。给定 k=2,应该将这三列顺次整体向右平移 1、2、1、2 位(如果有更多行,就应该按照 1、2、1、2、1、2 …… 这个规律顺次向右平移),左端的空位用 99 来填充。平移后的矩阵变成:
C:
int n, k, x, cnt = 1, Sum[100], A[100][100];
scanf("%d %d %d", &n, &k, &x);
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
for (int i = 0; i < n; i += 2) {
for (int j = 0; j < cnt; j++) {
for (int j = cnt; j < n; j++) {
for (int i = 0; i < n; i++) {
C++:
int n, k, x, cnt = 1, Sum[100], A[100][100];
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (i & 1) Sum[j] += A[i][j];
for (int i = 0; i < n; i += 2) {
for (int j = 0; j < cnt; j++) Sum[j] += x;
for (int j = cnt; j < n; j++) Sum[j] += A[i][j-cnt];
for (int i = 0; i < n; i++) {
Java:
import java.util.Scanner;
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
int k = scanner.nextInt();
int x = scanner.nextInt();
int[] Sum = new int[100];
int[][] A = new int[100][100];
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
A[i][j] = scanner.nextInt();
for (int i = 0; i < n; i += 2) {
for (int j = 0; j < cnt; j++) {
for (int j = cnt; j < n; j++) {
for (int i = 0; i < n; i++) {
System.out.print(Sum[i]);
Python:
n, k, x = map(int, input().split())
A = [[0] * 100 for _ in range(100)]
row = list(map(int, input().split()))