解题思路: 这个题目就是找规律,看下图:
2,0 | 3,2 | 4,4 | 0,1 | 1,3 |
1,4 | 2,1 | 3,3 | 4,0 | 0,2 |
0,3 | 1,0 | 2,2 | 3,4 | 4,1 |
4,2 | 0,4 | 1,1 | 2,3 | 3,0 |
3,1 | 4,3 | 0,0 | 1,2 | 2,4 |
import java.util.Scanner; public class C1188 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); while(sc.hasNext()){ int n = sc.nextInt(); if(n == 0) break; F(n); } sc.close(); } private static void F(int n){ int[][] a = new int[n][n]; int mid = (n-1)/2; a[mid][mid] = (n+1)/2; for(int j = 0; j < n; j++){ for(int i = 0; i < n; i++){ a[i][j] = (j-i+mid+n)%n*n + (j-i+j+n)%n + 1; } } int len = String.valueOf(n*n).length(); for(int i = 0; i < n; i++){ for(int j = 0; j < n; j++){ if(j < n-1) System.out.printf("%" + len + "d ", a[i][j]); else System.out.printf("%" + len + "d\n", a[i][j]); } } System.out.println(); } }
注意事项:
输出右对齐,对齐位数为 n*n 的位数
参考代码:
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:674 |
C语言训练-排序问题<1> (C++代码)浏览:632 |
C语言程序设计教程(第三版)课后习题8.3 (C语言代码)浏览:436 |
C语言程序设计教程(第三版)课后习题10.5 (C语言代码)浏览:566 |
WU-格式化数据输出 (C语言代码)浏览:1818 |
核桃的数量 (C语言代码)浏览:893 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:589 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)简单循环浏览:570 |
简单的a+b (C++代码)浏览:460 |
分解质因数 (C语言代码)浏览:862 |