日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

正方形分成16份,将1到16填入其中。让行和列都是从大到小。问一共有多少种方法?...

發布時間:2025/7/14 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 正方形分成16份,将1到16填入其中。让行和列都是从大到小。问一共有多少种方法?... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

看了到面試題:

將正方形分成16份,將1到16填入其中。讓行和列都是從大到小。問一共有多少種方法?

此題 解法有:

1。 窮舉,基本不用考慮 復雜度O(16!)。

2。 枚舉+剪枝 。代碼如下:得到答案是 24024

3。個人覺得 有簡單方法 再想想

方法2 代碼如下

#define?MAX?4
int?max_v(int?i,int?j)
{
????
return?(MAX?+1?-i)*(MAX+1?-?j)??-1;
}
bool?is_select(int?i,unsigned?int?stat)
{
????
return?stat&(1<<(i-1));
}
void?select(int?i?,unsigned?int?*?stat)
{
????
*stat?=?*stat|(1<<(i-1));
}
int?count(int?i?,int?j,int?s[MAX+1][MAX+1]?,unsigned?int?stat)
{
????
int?max1;
????
if?(s[i-1][j]?>?s[i][j-1])?
????????max1?
=?s[i][j-1];
????
else?
????????max1?
=?s[i-1][j];
????
int?min1?=?max_v(i,j);
????
//(max1?min1)
????if(min1>=max1-1)?return?0;
????
int?count_n?=?0;
????
for?(int?k?=?min1+1;k<max1;k++)
????{
????????
if(!is_select(k,stat))
????????{
????????????unsigned?
int?ss?=?stat;
????????????select(k,
&ss);
????????????s[i][j]?
=?k;
????????????
int?a,b;
????????????a
=i;b=j;
????????????
if?(b==MAX)
????????????{
????????????????
if?(a?==?MAX)
????????????????{
????????????????????
return?1;
????????????????}
????????????????b
=?1;
????????????????a
++;?
????????????}
????????????
else
????????????{
????????????????b
++;
????????????}
????????????count_n?
=?count_n?+?count(a,b,s,ss);
????????}
????}
????
return?count_n;
}
void?main()
{
????
int?f[MAX+1][MAX+1];
????
for?(int?i?=?0;i<MAX+1;i++)
????{
????????f[
0][i]?=?f[i][0]?=?MAX*MAX?+1;
????}

????unsigned?
int?t?=?0;
????cout
<<count(1,1,f,t);
}

?

?

轉載于:https://www.cnblogs.com/davidluo/articles/1799365.html

總結

以上是生活随笔為你收集整理的正方形分成16份,将1到16填入其中。让行和列都是从大到小。问一共有多少种方法?...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。