|
- //萬萬沒想到這幻方的求解還是世界性難題呢
- //看了答案才知道這是針對奇數階的幻方
- #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通信,能發送數據,接收不到數據
- • 菜鳥求助
- • 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 源程序
- • 單片機秒表程序到了指定時間不會停下來
|
|
|
|
|