|
- //万万没想到这幻方的求解还是世界性难题呢
- //看了答案才知道这是针对奇数阶的幻方
- #include<stdio.h>
- void main()
- {
- int i;//矩阵阶数
- int m,n,k;//k代表矩阵里面的元素
- int a[19][19];
- printf("please input a number which >=3&&<=19:\n");
- scanf("%d",&i);
- a[0][(i-1)/2]=1;
- m=0;
- n=(i-1)/2;
- for(k=2;k<=i*i;k++)
- {
- if(!(a[m-1][n+1]>=1&&a[m-1][n+1]<=(i*i))&&m>=1&&n<i-1) //1这一句是正常情况,要填的位置没有数字,而且前一位置不在最上边或最右边
- {
- a[m-1][n+1]=k;
- m=m-1;
- n=n+1;
- }
- else if(!(a[i-1][n+1]>=1&&a[i-1][n+1]<=(i*i))&&m==0&&n<i-1)//2这一句是行在最上边的情况,列不在最右边,要填的位置没有数字
- {
- a[i-1][n+1]=k;
- m=i-1;
- n=n+1;
- }
- else if(!(a[m-1][0]>=1&&a[m-1][0]<=(i*i))&&m>0&&n==i-1)//3这一句是行不在最上边,列在最右边,要填的位置没有数字
- {
- a[m-1][0]=k;
- m=m-1;
- n=0;
- }
- else if(!(a[i-1][0]>=1&&a[i-1][0]<=(i*i))&&m==0&&n==i-1)//4这一句是行列同时在最上面
- {
- a[i-1][0]=k;
- m=i-1;
- n=0;
- }
- else if(a[m-1][n+1]>=1&&a[m-1][n+1]<=(i*i)&&m>=1&&n<i-1)//1这种情况是要填的地方有数字,而且前一位置不在最上边或最右边
- {
- a[m+1][n]=k;
- m=m+1;
- }
- else if(a[i-1][n+1]>=1&&a[i-1][n+1]<=(i*i)&&m==0&&n<i-1)//2这种情况是要填的地方有数字,行在最上边的情况,列不在最右边,
- {
- a[1][n+1]=k;
- m=1;
- n=n+1;
- }
- else if(a[m-1][0]>=1&&a[m-1][0]<=(i*i)&&m>0&&n==i-1)//3这一句是行不在最上边,列在最右边,要填的位置有数字
- {
- a[m-1][i-1]=k;
- m=m-1;
- n=i-1;
- }
- else if(a[i-1][0]>=1&&a[i-1][0]<=(i*i)&&m==0&&n==i-1)//4这一句是行列同时在最上面,要填的位置有数字
- {
- a[1][i-1]=k;
- m=1;
- n=i-1;
- }
- else
- {
- for(m=0;m<=i-1;m++)//这一句是那里都不满足
- for(n=0;n<=i-1;n++)
- {
- if(a[m][n]<1&&a[m][n]>(i*i))
- a[m][n]=i*i;
- }
- }
- }
- for(m=0;m<=i-1;m++)
- {printf("\n");
- for(n=0;n<=i-1;n++)
- {printf("%5d",a[m][n]);}
- }
- printf("\n");
- }
复制代码
|
|
相关帖子
- • 这是定义的问题吗,用的c语言,怎么都改不对
- • adc_dma进行采集时打印数据为0,不开dma数据能够正常显示,想问一下是什么原因
- • 单片机不使用外部中断,如何LED显示程序?
- • 做了个替BF7612CM的测试
- • Keil程序求助,这些报错怎么解决,小白一个,刚接触单片机
- • 求用at89c51单片机测LM331 V/F转化后的频率 我的没有显示
- • MCU模拟SPI通信,能发送数据,接收不到数据
- • 菜鸟求助 这个问题怎么解决,已经在oledfont.h定义了 还是报错
- • STM32单片机向ESP8266发送指令,设置延时1秒上传一次数据,延时不准确
- • 单片机矩阵按键 原理图+源代码
- • 通过手机蓝牙APP发出控制指令,控制3个以上LED灯亮灭和蜂鸣器报警和关闭,怎么做 求指导
- • 关于用51单片机驱动AD9851的原理及其编程思路?
- • 单片机用点阵LED实现静态字符显示实验程序
- • 关于单片机矩阵键盘多位数的输入程序问题
- • CCS10.2编译器貌似不支持部分GNU的__attribute__
- • STM32于OLED1.54寸的屏幕资料
- • 基于89C52单片机的时钟设计经验分享
- • [原创文档分享]一步一步写带界面的程序(基于EasyX等库) 第三版 C/C++语言
- • arduino due时钟 气象站制作 at24c w25q esp8266 源程序
- • 单片机秒表程序到了指定时间不会停下来
|
|
|
|
|