牛哥们,帮忙求解N阶拉丁方阵

kitcaii 2008-06-07 01:33:56
在N行N列的数阵中, 数K(1〈=K〈=N)在每行和每列中出现且仅
出现一次,这样的数阵叫N阶拉丁方阵。例如下图就是一个五阶拉丁方阵。
编一程序,从键盘输入N值后,打印出所有不同的N阶拉丁方阵,并统计个数。

1 2 3 4 5
2 3 4 5 1
3 4 5 1 2
4 5 1 2 3
5 1 2 3 4
...全文
779 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
fighthoo 2010-12-11
  • 打赏
  • 举报
回复
如何用vb来求解,跪求高手解答
fighthoo 2010-12-11
  • 打赏
  • 举报
回复
如何用vb来解这道题呢
李V四 2008-06-07
  • 打赏
  • 举报
回复
#include <stdio.h>

#define MAXMATRIXSIZE 100

int MatrixPrint(int nMatrixSize);
void ClearMartix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE]);
int MatrixCau(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nMatrixSize );
bool CanEqualTo(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nValue);
void PrintMatrix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],int nMatrixSize);

int main(int argc ,char * argv[])
{
int nMatrixSize=1;

printf("请输入拉丁方阵的大小:\n");

if(scanf("%d",&nMatrixSize) == 0 ||
nMatrixSize <= 0)
{
printf("你输入的不是一个大于零的整数!\n");
return 1;
}
else if(nMatrixSize > MAXMATRIXSIZE)
{
printf("你输入数超出了设定的最大值!\n");
return 1;
}

int nSize = MatrixPrint(nMatrixSize);

printf("拉丁方阵的总数:%d\n",nSize);

return 0;
}

int MatrixPrint(int nMatrixSize)
{
int nSize = 0;

int MATRIX[MAXMATRIXSIZE][MAXMATRIXSIZE];

ClearMartix(MATRIX);

return MatrixCau(MATRIX,0,0,nMatrixSize);
}

void ClearMartix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE])
{
for(int i=0 ; i<MAXMATRIXSIZE ; i++)
{
for(int j=0 ; j<MAXMATRIXSIZE ; j++)
{
Martrix[i][j] = 0;
}
}
}

void PrintMatrix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],int nMatrixSize)
{
for(int i=0 ; i<nMatrixSize ; i++)
{
for(int j=0 ; j<nMatrixSize ; j++)
{
printf("%3d",Martrix[i][j]);
}
printf("\n");
}

printf("\n");
}

bool CanEqualTo(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nValue)
{
for(int i=0 ; i<xPoint ; i++)
{
if(Martrix[yPoint][i] == nValue)
{
return false;
}
}

for(int j=0 ; j<yPoint ; j++)
{
if(Martrix[j][xPoint] == nValue)
{
return false;
}
}

return true;
}

int MatrixCau(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nMatrixSize )
{
int nSize = 0;

for(int i = 1 ; i <= nMatrixSize ; i++ )
{
if(CanEqualTo(Martrix,xPoint,yPoint,i))
{
Martrix[yPoint][xPoint] = i;

if(xPoint ==nMatrixSize-1 && yPoint == nMatrixSize-1)
{
PrintMatrix(Martrix,nMatrixSize);
nSize += 1;
continue;
}

if(xPoint == nMatrixSize-1 )
{
nSize += MatrixCau(Martrix,0,yPoint+1,nMatrixSize);
}
else
{
nSize += MatrixCau(Martrix,xPoint+1,yPoint,nMatrixSize);
}

}
}

return nSize;
}
iu_81 2008-06-07
  • 打赏
  • 举报
回复
#include<stdio.h>
#define N 6 /*确定N值*/
int main()
{
int i,j,k,t;
printf("The possble Latin Squares of order %d are:\n",N);
for(j=0;j<N;j++) /*构造N个不同的拉丁方阵*/
{
for(i=0;i<N;i++)
{
t=(i+j)%N; /*确定该拉丁方阵第i 行的第一个元素的值*/
for(k=0;k<N;k++) /*按照环的形式输出该行中的各个元素*/
printf("%d ",(k+t)%N+1);
printf("\n");
}
printf("\n");
}
}
李V四 2008-06-07
  • 打赏
  • 举报
回复
int nMatrixSize=1; 

printf("请输入拉丁方阵的大小:\n");
李V四 2008-06-07
  • 打赏
  • 举报
回复
4楼的怎么弄成 c++ code?
李V四 2008-06-07
  • 打赏
  • 举报
回复
[BanUBB]{int nMatrixSize=1;

printf("请输入拉丁方阵的大小:\n");}[/BanUBB]
iu_81 2008-06-07
  • 打赏
  • 举报
回复

#include <stdio.h>
int n;
int i,j;
int main()
{
scanf("%d",&n);
for (i=0;i<n;i++)
{
for (j=0;j<n;j++) printf("%d ",(i+j)%n+1);
putchar('\n');
}
return 0;
}
李V四 2008-06-07
  • 打赏
  • 举报
回复
[code={0}]测试CODE[/code]
李V四 2008-06-07
  • 打赏
  • 举报
回复
[code={3}]测试CODE[/code]
李V四 2008-06-07
  • 打赏
  • 举报
回复
#include <stdio.h>

#define MAXMATRIXSIZE 100

int MatrixPrint(int nMatrixSize);
void ClearMartix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE]);
int MatrixCau(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nMatrixSize );
bool CanEqualTo(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nValue);
void PrintMatrix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],int nMatrixSize);

int main(int argc ,char * argv[])
{
int nMatrixSize=1;

printf("请输入拉丁方阵的大小:\n");

if(scanf("%d",&nMatrixSize) == 0 ||
nMatrixSize <= 0)
{
printf("你输入的不是一个大于零的整数!\n");
return 1;
}
else if(nMatrixSize > MAXMATRIXSIZE)
{
printf("你输入数超出了设定的最大值!\n");
return 1;
}

int nSize = MatrixPrint(nMatrixSize);

printf("拉丁方阵的总数:%d\n",nSize);

return 0;
}

int MatrixPrint(int nMatrixSize)
{
int nSize = 0;

int MATRIX[MAXMATRIXSIZE][MAXMATRIXSIZE];

ClearMartix(MATRIX);

return MatrixCau(MATRIX,0,0,nMatrixSize);
}

void ClearMartix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE])
{
for(int i=0 ; i<MAXMATRIXSIZE ; i++)
{
for(int j=0 ; j<MAXMATRIXSIZE ; j++)
{
Martrix[i][j] = 0;
}
}
}

void PrintMatrix(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],int nMatrixSize)
{
for(int i=0 ; i<nMatrixSize ; i++)
{
for(int j=0 ; j<nMatrixSize ; j++)
{
printf("%3d",Martrix[i][j]);
}
printf("\n");
}

printf("\n");
}

bool CanEqualTo(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nValue)
{
for(int i=0 ; i<xPoint ; i++)
{
if(Martrix[yPoint][i] == nValue)
{
return false;
}
}

for(int j=0 ; j<yPoint ; j++)
{
if(Martrix[j][xPoint] == nValue)
{
return false;
}
}

return true;
}

int MatrixCau(int Martrix[MAXMATRIXSIZE][MAXMATRIXSIZE],
int xPoint,int yPoint,int nMatrixSize )
{
int nSize = 0;

for(int i = 1 ; i <= nMatrixSize ; i++ )
{
if(CanEqualTo(Martrix,xPoint,yPoint,i))
{
Martrix[yPoint][xPoint] = i;

if(xPoint ==nMatrixSize-1 && yPoint == nMatrixSize-1)
{
PrintMatrix(Martrix,nMatrixSize);
nSize += 1;
continue;
}

if(xPoint == nMatrixSize-1 )
{
nSize += MatrixCau(Martrix,0,yPoint+1,nMatrixSize);
}
else
{
nSize += MatrixCau(Martrix,xPoint+1,yPoint,nMatrixSize);
}

}
}

return nSize;
}
Learn-anything 2008-06-07
  • 打赏
  • 举报
回复
飘过
medie2005 2008-06-07
  • 打赏
  • 举报
回复
如果全部列出,当N=10时有9982437658213039871725064756920320000个拉丁方,全部输出要多久?
就算考虑只列出实质上不同的拉丁方(有些拉丁方可以由其他的翻转得到),N=10时也有208904371354363006个,输出也够呛。

也就是说,这个题中的N的可计算的值很少,如果真要列出,比较好的算法是用Knuth提出的DLX算法。
kitcaii 2008-06-07
  • 打赏
  • 举报
回复
9楼的,能把MatrixCau()和CanEqualTo()这2个函数注释一下吗,看不太懂
kitcaii 2008-06-07
  • 打赏
  • 举报
回复
8楼的计算出来的不全面啊 n=3的时候就有12个
资源下载链接为: https://pan.quark.cn/s/d0b0340d5318 晶晨线刷固件解包打包v4.0是由超级小哥开发的一款专门针对晶晨系盒子的实用工具,主要用于处理晶晨芯片设备的固件更新。它具备解包和打包两大核心功能,是用户在系统升级、修复或进行自定义设置时的重要辅助工具。 解包功能可以将原始线刷包(.img后缀)拆解,让用户能够查看和修改固件中的各个部分。这对于开发者和高级用户非常有用,他们可能需要深入固件内部,检查或调整系统配置、驱动程序或应用程序。解包过程通常会分离bootloader、kernel、rootfs等关键组件,方便用户单独操作和定制。 打包功能则是将修改后的文件重新组合成可用于线刷的固件包(通常为.zip格式)。在这个过程中,需要确保所有组件正确整合,并保持固件的完整性和可刷写性。打包工具还会自动生成必要的结构和文件,如批处理脚本或安装指南,以帮助用户顺利进行刷机操作。 晶晨系盒子是指使用晶晨公司芯片的智能电视盒或电视棒。晶晨(Amlogic)是一家知名的半导体公司,其芯片因在高清视频和音频处理方面的出色表现而广受市场欢迎。因此,这款解包打包工具对于晶晨系盒子用户来说,是进行系统维护和优化的必备工具。 使用该工具时,用户需将卡刷包(.zip后缀)直接放在工具目录下,而线刷包(.img后缀)则需放入工具目录内的“in”子文件夹。这种文件组织结构便于工具自动识别和处理不同类型的固件。 晶晨线刷固件解包打包v4.0是一款专业且实用的工具,为晶晨系盒子用户提供了提升设备性能、增加功能或解决系统问题的强大支持,帮助用户解锁设备潜能。然而,固件操作存在一定风险,可能导致设备无法正常工作,因此建议用户在使用前充分了解相关知识,并谨慎操作。

65,209

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧