Problem C: 铺地砖——迭代小算法

搜了一下百度,网上很多人都对这题没有深入下去进行解释,大多数只是通过枚举法就得出结论,因此我写了这篇博客讲讲我对这个题目的理解。

首先这道题目通过枚举法可以发现从第四项开始,方法总数就是前三项的和了,然后不断重复迭代就可以得出结论。

但是这又是为什么呢?这其中要如何去解释呢?

我就简单谈谈我的理解(我也是新手,大佬勿喷),设a[n]为铺满长方形1×n的方法数。

首先,自第四项开始,n就是大于等于4了,也就是说,我们可以先将n分成1和n-1,然后a[n-1]我们之前已经求出来,因此这边就直接拿过来加,

再之后我们将n分成2和n-2,这里要理解一下为什么不会和上述产生重复,因为我们主要针对的主体是前面那部分长度,只要前面那部分长度不一样,那么我们通过a[n-1]和a[n-2]加起来的情况就不会重复(这是这个题目的关键所在,不懂的可以在纸上画一下马上就能明白了),

之后就是分成3和a[n-3],然后再加上a[n-3],这个时候就不需要分成4和a[n-4]了,因为,小瓷砖最长为3,如果要变成4,必然涉及到俩块以上瓷砖的组合,这就会与上述三种情况重复。

因此,得出核心式子,a[n]=a[n-1]+a[n-2]+a[n-3];

Problem C: 铺地砖

Time Limit: 1 Sec Memory Limit: 64 MB
Submit: 5332 Solved: 1985

Description

元旦过去了,新年大酬宾活动也已经告一段落了。陈盖历望着堆在仓库的瓷砖,很无聊的他把这些瓷砖裁成很多1X1 1X2 1X3的小瓷砖,然后他把这些小瓷砖排在地上画的一个1*n的长方形里。问铺满这个长方形共有多少种方法?

Input

首先输入一个整数T,表示有T组测试数据 然后是T行,每行输入1个正整数n(n<=50)

Output

对于每个n输出铺的方法种数

Sample Input

3
1
2
3

Sample Output

1
2
4

代码如下:

#include<stdio.h>
int main()
{
	int a[51]={0,1,2,4};
	int n,i;
	for(i=4;i<=50;i++)
	{
		a[i]=a[i-1]+a[i-2]+a[i-3];
	}
	while(scanf("%d",&n)!=EOF)
	{
		while(n--)
		{
			int x;
			scanf("%d",&x);
			printf("%d\n",a[x]);
		}	
	}
}

实现很简单,这里就不加注释了。。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答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()的方法较为简单和直观,但如果想要了解更多底层的实现细节,逐个字符遍历的方法也是一种不错的选择。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值