欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 2574|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

c語言 幻方&分類討論

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:72519 發(fā)表于 2015-1-22 02:28 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
  1. //萬萬沒想到這幻方的求解還是世界性難題呢
  2. //看了答案才知道這是針對(duì)奇數(shù)階的幻方
  3. #include<stdio.h>
  4. void main()
  5. {
  6. int i;//矩陣階數(shù)
  7. int m,n,k;//k代表矩陣?yán)锩娴脑?br />
  8. int a[19][19];
  9. printf("please input a number which >=3&&<=19:\n");
  10. scanf("%d",&i);
  11. a[0][(i-1)/2]=1;
  12. m=0;
  13. n=(i-1)/2;
  14.     for(k=2;k<=i*i;k++)
  15. {
  16.     if(!(a[m-1][n+1]>=1&&a[m-1][n+1]<=(i*i))&&m>=1&&n<i-1) //1這一句是正常情況,要填的位置沒有數(shù)字,而且前一位置不在最上邊或最右邊
  17. {
  18.     a[m-1][n+1]=k;
  19. m=m-1;
  20. n=n+1;
  21. }
  22. else if(!(a[i-1][n+1]>=1&&a[i-1][n+1]<=(i*i))&&m==0&&n<i-1)//2這一句是行在最上邊的情況,列不在最右邊,要填的位置沒有數(shù)字
  23. {
  24. a[i-1][n+1]=k;
  25. m=i-1;
  26. n=n+1;
  27. }
  28. else if(!(a[m-1][0]>=1&&a[m-1][0]<=(i*i))&&m>0&&n==i-1)//3這一句是行不在最上邊,列在最右邊,要填的位置沒有數(shù)字
  29. {
  30. a[m-1][0]=k;
  31. m=m-1;
  32. n=0;
  33. }
  34. else if(!(a[i-1][0]>=1&&a[i-1][0]<=(i*i))&&m==0&&n==i-1)//4這一句是行列同時(shí)在最上面
  35. {
  36. a[i-1][0]=k;
  37. m=i-1;
  38. n=0;
  39. }
  40. else if(a[m-1][n+1]>=1&&a[m-1][n+1]<=(i*i)&&m>=1&&n<i-1)//1這種情況是要填的地方有數(shù)字,而且前一位置不在最上邊或最右邊
  41. {
  42. a[m+1][n]=k;
  43. m=m+1;
  44. }
  45.     else if(a[i-1][n+1]>=1&&a[i-1][n+1]<=(i*i)&&m==0&&n<i-1)//2這種情況是要填的地方有數(shù)字,行在最上邊的情況,列不在最右邊,
  46. {
  47. a[1][n+1]=k;
  48. m=1;
  49. n=n+1;
  50. }
  51.     else if(a[m-1][0]>=1&&a[m-1][0]<=(i*i)&&m>0&&n==i-1)//3這一句是行不在最上邊,列在最右邊,要填的位置有數(shù)字
  52. {
  53. a[m-1][i-1]=k;
  54. m=m-1;
  55. n=i-1;
  56. }
  57. else if(a[i-1][0]>=1&&a[i-1][0]<=(i*i)&&m==0&&n==i-1)//4這一句是行列同時(shí)在最上面,要填的位置有數(shù)字
  58. {
  59. a[1][i-1]=k;
  60. m=1;
  61. n=i-1;
  62. }
  63. else
  64. {
  65. for(m=0;m<=i-1;m++)//這一句是那里都不滿足
  66.        for(n=0;n<=i-1;n++)
  67.   {
  68.   if(a[m][n]<1&&a[m][n]>(i*i))
  69.   a[m][n]=i*i;
  70.   }
  71. }
  72. }

  73. for(m=0;m<=i-1;m++)
  74. {printf("\n");
  75.        for(n=0;n<=i-1;n++)
  76.   {printf("%5d",a[m][n]);}
  77. }
  78. printf("\n");
  79. }
復(fù)制代碼


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩

相關(guān)帖子

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表