蓝桥杯-切面条

烟大OJ-2506

Description

一根高筋拉面,中间切一刀,可以得到2根面条。
    如果先对折1次,中间切一刀,可以得到3根面条。
    如果连续对折2次,中间切一刀,可以得到5根面条。
    那么,连续对折10次,中间切一刀,会得到多少面条呢?

Input

包含多组数据,首先输入T,表示有T组数据.每个数据一行,是对折的次数。

Output

每行一组数据,输出得到的面条数。

Sample Input

3
0
1
2

Sample Output

2
3
5

code循环
 1 #include <iostream>
 2 using namespace std;
 3 int main()
 4 {
 5     int i,j,t,n,two=1,sum=2;
 6     cin>>t;
 7     for(i=1;i<=t;i++)
 8     {
 9         cin>>n;
10         sum=2,two=1;
11         for(j=0;j<n;j++)
12         {
13             sum+=two;
14             two*=2;
15         }
16         cout<<sum<<endl;
17     }
18     return 0;
19 }

递归

#include <iostream>
using namespace std;
int noodle(int n);
int main()
{
    int i;
    int n,m;
    cin>>n;
    for(i=1;i<=n;i++)
    {
        cin>>m;
        cout<<noodle(m)<<endl;
    }
    return 0;
}

int noodle(int n)
{
    int i,two=1;
    if(n==0)
        return 2;
    else
    {
        for(i=1;i<n;i++)
            two*=2;
        return noodle(n-1)+two;
    }
}

递归2

 1 #include <iostream>
 2 using namespace std;
 3 int f(int n)
 4 {
 5     //基本递归
 6     if(n == 0)
 7     {
 8         return 2;
 9     }
10     else
11     {
12         return 2 * f(n - 1) - 1;
13     }
14 }
15 int main(void)
16 {
17     cout << f(10) << endl;
18     return 0;
19 }

递归3

#include <iostream>
using namespace std;
int f2(int n, int r)
{    //尾递归
    if(n == 0)
    {
        return r;
    }
    else
    {
        return f2(n - 1, 2 * r - 1);
    }
}
int main(void)
{
    cout << f2(10, 2) << endl;
    return 0;
}

1.递归重要的是总结出递归公式!

2.不要在递归函数中定义变量,真的很蹩脚。

时间: 2024-08-05 06:36:43

蓝桥杯-切面条的相关文章

蓝桥杯:切面条

*/--> pre.src {background-color: Black; color: White;} pre.src {background-color: Black; color: White;} 蓝桥杯:切面条 标题:切面条 一根高筋拉面,中间切一刀,可以得到 2 根面条. 如果先对折 1 次,中间切一刀,可以得到 3 根面条. 如果连续对折 2 次,中间切一刀,可以得到 5 根面条. 那么,连续对折 10 次,中间切一刀,会得到多少面条呢? 答案是个整数,请通过浏览器提交答案.不要

算法笔记_208:第六届蓝桥杯软件类决赛真题(Java语言A组)

目录 1 胡同门牌号 2 四阶幻方 3 显示二叉树 4 穿越雷区 5 切开字符串 6 铺瓷砖   前言:以下代码仅供参考,若有错误欢迎指正哦~ 1 胡同门牌号 标题:胡同门牌号 小明家住在一条胡同里.胡同里的门牌号都是连续的正整数,由于历史原因,最小的号码并不是从1开始排的. 有一天小明突然发现了有趣的事情: 如果除去小明家不算,胡同里的其它门牌号加起来,刚好是100! 并且,小明家的门牌号刚好等于胡同里其它住户的个数! 请你根据这些信息,推算小明家的门牌号是多少? 请提交该整数,不要填写任何多

2015年蓝桥杯省赛B组C/C++(试题+答案)

首先说,这次我是第二次参加蓝桥杯(大学里最后一次),可这次去连个三等都没拿到,有些心灰意冷,比上一次还差, 当时看到成绩出来的时候有些失落,但是跌倒了,再站起来继续跑就可以了.可能是状态不好吧,纯属自我安慰. 接下来我把今年的题目又重新做了一遍,写下了这篇博客,如果也有需要探讨答案的,希望可以有帮助. 第一题: 第1题:统计不含4的数字 题目大意 统计10000至99999中,不包含4的数值个数. 解题分析: 第一种解法: 数学方法,这种是在网上看到的一种解法: 最高位除了0.4不能使用,其余8

蓝桥杯——算法训练之乘积最大

问题描述 今年是国际数学联盟确定的"2000--世界数学年",又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得以参加.活动中,主持人给所有参加活动的选手出了这样一道题目: 设有一个长度为N的数字串,要求选手使用K个乘号将它分成K+1个部分,找出一种分法,使得这K+1个部分的乘积能够为最大. 同时,为了帮助选手能够正确理解题意,主持人还举了如下的一个例子: 有一个数字串:312, 当N=3,K=1时

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告

2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告 勘误1:第6题第4个 if最后一个条件粗心写错了,答案应为1580. 条件应为abs(a[3]-a[7])!=1,宝宝心理苦啊.!感谢zzh童鞋的提醒. 勘误2:第7题在推断连通的时候条件写错了,后两个if条件中是应该是<=12 落了一个等于号.正确答案应为116. 1.煤球数目 有一堆煤球.堆成三角棱锥形.详细: 第一层放1个, 第二层3个(排列成三角形), 第三层6个(排列成三角形), 第四层10个(排列成三角形). -. 假设一共

蓝桥杯——判定字符的位置。

蓝桥杯——判断字符的位置 题目: 输入一个字符串,编写程序输出该字符串中元音字母的首次出现位置,如果没有元音字母输出0.英语元音字母只有‘a’.‘e’.‘i’.‘o’.‘u’五个. 样例输入: hello样例输出:2 样例输入: apple样例输出:1 样例输入: pmp样例输出:0 java code: import java.util.*;public class Yuanyingzifu {    public static int fun(String str)    {        

蓝桥杯 地宫取宝(12&#39;)

X 国王有一个地宫宝库.是n x m 个格子的矩阵.每个格子放一件宝贝.每个宝贝贴着价值标签. 地宫的入口在左上角,出口在右下角. 小明被带到地宫的入口,国王要求他只能向右或向下行走. 走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大, 小明就可以拿起它(当然,也可以不拿). 当小明走到出口时,如果他手中的宝贝恰好是k件,则这些宝贝就可以送给小明. 请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这k件宝贝. [数据格式] 输入一行 3个整数,用空格分开:n m

蓝桥杯-开心的金明

//蓝桥杯-算法训练 开心的金明 //评测结果 AC //动态规划 01背包 #include <cstdio> #include <algorithm> #include <cstring> using namespace std; const int maxn = 30005; int main() { int N, m; scanf( "%d%d", &N, &m ); int f[maxn]; int v, w; memset

第六届蓝桥杯2015-省赛-C语言大学B组 个人题解

题目连接:http://course.baidu.com/view/2d86a6c1960590c69fc37622.html 1,奖券数目52488 #include <iostream> using namespace std; bool isOK(int a) { while(a) { if(a%10==4) return false; a /= 10; } return true; } int main() { int ans = 0; for(int i=10000; i<=9