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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

POJ 放苹果问题(递归)

發布時間:2025/3/18 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 POJ 放苹果问题(递归) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

首先我們想象有一個函數count(m,n)可以把m個蘋果放到n個盤子中。

?

根據 n 和 m 的關系可以進一步分析:

  特殊的m <=1|| n <= 1時只有一種方法;

  當 m < n時,即使蘋果每個盤子放一個也沒法放滿所有盤子,題目允許有的盤子空著不放,所以我們可以將空盤子去掉,即 count ( m , n ) = count ( m , m );

  當 m >= n時,這時候有兩種情況:

  n 個盤子中有一個空盤子,當有空盤子時,count ( m , n ) = count ( m , n - 1 );

  n個盤子中沒有空盤子,當沒有空盤子時也就是說每個盤子中至少有一個蘋果,先把所有盤子填滿,這時候會剩下 m - n 個蘋果,所以現在問題變成了 m - n 個蘋果放在 n 個盤子有多少種方法,即 count ( m - n , n )。

? ? ? 所以當m>=n時,放置蘋果的總情況為?count ( m , n - 1 )+?count ( m - n , n )次。

  具體代碼實現如下:

#include <iostream> using namespace std; int count(int m, int n) {if (m <=1|| n <= 1) return 1;if (m < n)return count(m, m);elsereturn count(m, n - 1) + count(m - n, n); } int main() {int m, n;cin >> m >> n;cout << count(m, n) << endl;return 0; }

?

?

轉載于:https://www.cnblogs.com/joy-1120/p/8973346.html

總結

以上是生活随笔為你收集整理的POJ 放苹果问题(递归)的全部內容,希望文章能夠幫你解決所遇到的問題。

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