动态规划——problem g

都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼。说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的10米范围内。馅饼如果掉在了地上当然就不能吃了,所以gameboy马上卸下身上的背包去接。但由于小径两侧都不能站人,所以他只能在小径上接。由于gameboy平时老呆在房间里玩游戏,虽然在游戏中是个身手敏捷的高手,但在现实中运动神经特别迟钝,每秒种只有在移动不超过一米的范围内接住坠落的馅饼。现在给这条小径如图标上坐标:<br><center><img src=../../../data/images/1176_1.jpg></center><br>为了使问题简化,假设在接下来的一段时间里,馅饼都掉落在0-10这11个位置。开始时gameboy站在5这个位置,因此在第一秒,他只能接到4,5,6这三个位置中其中一个位置上的馅饼。问gameboy最多可能接到多少个馅饼?(假设他的背包可以容纳无穷多个馅饼)


思路:

 5                                 i = 0;

            5 6 7                              i = 1;  

         4 5 6 7 8                           i = 2;

      3 4 5 6 7 8 9                         i = 3;

   2 3 4 5 6 7 8 9 10                     i = 4;

1 2 3 4 5 6 7 8 9 10 11                i = 5;

1 2 3 4 5 6 7 8 9 10 11                i = 6;

。。。。。。。。。。。。                。。。

状态转移方程:dp[i][j] += max(max(dp[i+1][j-1], dp[i+1][j+1]),  dp[i+1][j]);

#include<stdio.h>

#include<algorithm>
#include<string.h>
using namespace std;


const int N=100010;
const int INF=0x3f3f3f3f;


int dp[N][20];


int main ()
{
    int n, i, j, M, x, T;


    while (scanf("%d", &n), n)
    {
        memset(dp, 0, sizeof(dp));
        M = -INF;


        for (i = 1; i <= n; i++)
        {
            scanf("%d%d", &x, &T);
            M = max(M, T);
            dp[T][x+1]++;
        }


        for (i = M; i >= 0; i--)
        {
            for (j = 1; j <= 11; j++)
                dp[i][j] += max(max(dp[i+1][j-1], dp[i+1][j+1]), dp[i+1][j]);
        }


        printf("%d\n", dp[0][6]);
    }


    return 0;
}
### 回答1: 这道题目要求我们将字符串中每个单词的首字母变成大写。我们可以先将字符串按照空格分割成单词,然后对每个单词进行处理。处理的方法是将单词的第一个字符转换成大写,然后再将剩余的字符拼接起来。最后将处理后的单词再拼接成一个字符串即可。 ### 回答2: 题目要求编写一个程序,将给定字符串的每个单词的首字母变为大写。 首先,我们可以使用`split()`方法将字符串分割成单词的列表。然后,遍历每个单词,将首字母转化成大写。最后,使用`join()`方法将单词列表重新连接成字符串,得到结果。 以下是一个可能的实现: ```python def capitalize_first_letter(sentence): words = sentence.split() # 将字符串分割成单词列表 result = [] for word in words: capitalized_word = word[0].upper() + word[1:] # 将首字母变为大写 result.append(capitalized_word) return ' '.join(result) # 将单词列表重新连接成字符串 # 测试示例 print(capitalize_first_letter('hello world')) # 输出: Hello World print(capitalize_first_letter('zero starting point')) # 输出: Zero Starting Point ``` 以上代码中,`capitalize_first_letter`函数接收一个字符串作为参数,并返回首字母变为大写的结果字符串。我们将字符串使用`split()`方法分割成单词列表,然后遍历每个单词,将首字母转化成大写。最后,使用`join()`方法将单词列表重新连接成字符串,并返回结果。 通过上述实现,我们可以满足题目要求,将给定字符串的每个单词的首字母变为大写。 ### 回答3: 问题g:零起点学算法106——首字母变大写 这个问题要求我们将给定字符串中每个单词的首字母变为大写。解决这个问题的方法有很多种,下面我将提供两种方法。 方法一:使用内置函数capitalize() 我们可以使用内置函数capitalize()来将字符串的首字母变为大写。首先,我们将给定的字符串按照空格分割成单词列表。然后,对于每个单词,我们使用capitalize()函数将其首字母变为大写,并将其添加到结果列表中。最后,我们将结果列表连接成一个字符串,并返回这个结果字符串作为答案。 def capitalize_words(sentence): words = sentence.split() capitalized_words = [word.capitalize() for word in words] return ' '.join(capitalized_words) 方法二:逐个字符遍历 我们也可以逐个字符遍历给定字符串,当遇到空格,将下一个字符变为大写。为了解决字符串首字母的问题,我们可以在遍历前在字符串的首部添加一个空格。 def capitalize_words(sentence): sentence = ' ' + sentence n = len(sentence) result = '' for i in range(1, n): if sentence[i - 1] == ' ': result += sentence[i].upper() else: result += sentence[i] return result 这两种方法都可以解决问题g中的要求,使用内置函数capitalize()的方法较为简单和直观,但如果想要了解更多底层的实现细节,逐个字符遍历的方法也是一种不错的选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值