标签:不同 head alt 物理学 fallback pac row 拉丁字母 情况
拉丁方阵(英语:Latin square)是一种 n × n 的方阵,在这种 n × n 的方阵里,恰有 n 种不同的元素,每一种不同的元素在同一行或同一列里只出现一次。以下是两个拉丁方阵举例:
拉丁方阵有此名称是因为瑞士数学家和物理学家欧拉使用拉丁字母来做为拉丁方阵里的元素的符号。
算法步骤:
1 package algorithm; 2 3 /** 4 * 拉丁方阵 5 */ 6 public class LatinSquare { 7 /** 8 * 打印拉丁方阵 9 * 10 * @param n 方阵边长 11 */ 12 private static void printLatin(int n) { 13 int k = n + 1; 14 15 // row 16 for (int i = 1; i <= n; i++) { 17 int temp = k; 18 19 while (temp <= n) { 20 System.out.print(temp + " "); 21 temp++; 22 } 23 24 // 每行后面补 1...k-1 25 for (int j = 1; j < k; j++) { 26 System.out.print(j + " "); 27 } 28 29 k--; 30 System.out.println(); 31 } 32 } 33 34 public static void main(String[] args) { 35 int n = 5; 36 printLatin(n); 37 } 38 }
设有两个阶数相同(为)的拉丁方阵,其中将所有放置位置相同的元素组合成一个元组,组合成一个新的矩阵。 当这个新的矩阵中每一个元素互不相同时,拉丁方阵和 是互相正交的。 此时,和即为一对正交拉丁方。 而在阶数固定的情况下,所有两两正交的拉丁方所成的集合称为正交拉丁方族。
如当 n=3 时,存在两个正交的拉丁方。
可能有不止一种可能的拉丁方形。
目前,没有公式可以计算 n × n 的拉丁方阵的数量,而当前最精确的公式在当 n 很大时,拉丁方阵的数量的最精确的估计值,其上下界也相差很远。 具体估计公式为:
标签:不同 head alt 物理学 fallback pac row 拉丁字母 情况
原文地址:https://www.cnblogs.com/magic-sea/p/12111763.html