逃离农场--动态规划

题目:

牛牛在农场饲养了n只奶牛,依次编号为0到n-1, 牛牛的好朋友羊羊帮牛牛照看着农场.有一天羊羊看到农场中逃走了k只奶牛,但是他只会告诉牛牛逃走的k只奶牛的编号之和能被n整除。你现在需要帮牛牛计算有多少种不同的逃走的奶牛群。因为结果可能很大,输出结果对1,000,000,007取模。

例如n = 7 k = 4:
7只奶牛依次编号为0到6, 逃走了4只
编号和为7的有:{0, 1, 2, 4}
编号和为14的有:{0, 3, 5, 6}, {1, 2, 5, 6}, {1, 3, 4, 6},{2, 3, 4, 5}
4只牛的编号和不会大于18,所以输出5. 
输入描述:
输入包括一行,两个整数n和k(1 ≤ n ≤ 1000),(1 ≤ k ≤ 50),以空格分割。
输出描述:
输出一个整数表示题设所求的种数。
示例1

输入

7 4

输出

5

分析思路:
dp[j][s]这个是通过状态压缩后的形式,最初的形式应该是dp[i][j][s],代表从[0,i]中取j个数,使他们的和与n的模余数为s,这样的j的数的集合的个数。
状态转移方程:
dp[i][j][s]=(dp[i-1][j][s]+dp[i-1][j-1][(n+s-i)%n])
转移的过程就是第i个数取还是不取,如果不取,那么就和方法i-1的个数相同;如果取第i个数的话,那么就需要分两种情况,因为第i个数可能大于s,也有可能小于等于s。 情况1:若i<=s,此时我们需要从前i-1个数中取j-1个数,使他们的和与n的模为s-i。这样就能保证在加入i时,和模n等于s。情况2:如果i>s,那么i-s为负数,注意本题的要求是组成和为n的倍数,因此这种情况下需要将(s-i)%n表示为(s-i+n)%n,因为
((s-i+n)%n+i)%n=s。这个式子对于第一种情况也成立,因此合在一起就可以了
代码:
#include <iostream>
using namespace std;
const int modMin=1e9+7;
int main()
  {
    int dp[55][1005];
    dp[0][0]=1;
    int n,k;
    while(cin>>n>>k)
      {
         for(int i=0;i<n;i++)
           {
              for(int j=k;j>=1;j--)
               {
                  for(int s=0;s<n;s++)
                    {
                       dp[j][s]=(dp[j][s]+dp[j-1][(n+s-i)%n])%modMin;
                    }
               }
           }
         cout<<dp[k][0]<<endl;
      }
    return 0;
  }


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
对于守望者的逃离这道题目,可以使用动态规划或贪心算法来解决。首先我们需要理解题目的要求,甲在光明大道的起始点,每秒有三种选择:1.行使17m,2.在蓝量足够的情况下行使60m,蓝量减去10,3.行使0m,恢复4蓝量。我们需要判断甲能否在初始蓝量为m的情况下在t秒内到达终点。 为了解决这个问题,我们可以使用一个循环来模拟每一分钟的情况。假设甲在当前的时间点有一定的蓝量,我们可以计算出他在下一分钟时的蓝量,并根据这个蓝量来判断他的行动选择。如果蓝量足够,我们选择行使60m并减去10的蓝量;如果蓝量不足,我们选择行使17m;如果蓝量为0,我们选择恢复4蓝量。 在每一分钟的计算中,我们需要对甲的位置进行更新,并记录下他到达终点的最短时间。当循环结束后,我们可以得到甲是否能在规定时间内到达终点,如果能,输出"Yes"并换行输出所需时间;如果不能,输出"No"并换行输出甲最长能达到的距离。 这样,我们就可以使用C语言编写代码来解决守望者的逃离这道题目了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [[NOIP2007 普及组] 守望者的逃离](https://blog.csdn.net/TGxyt_blog/article/details/122783995)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

rs勿忘初心

您的鼓励将是我的最大创动原动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值