PTA——猴子吃桃问题

一只猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个;第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半加一个。到第N天早上想再吃时,见只剩下一个桃子了。问:第一天共摘了多少个桃子?

输入格式:

输入在一行中给出正整数N(1<N≤10)。

输出格式:

在一行中输出第一天共摘了多少个桃子。

输入样例:

复制代码
3

输出样例:

复制代码
10
cs 复制代码
#include<stdio.h>

int main()
{
    int n;
    scanf("%d",&n);
    int d=1;
    for(int i=1;i<n;i++)
    {

        
        d=d+1;
d*=2;
        
}
    printf("%d",d);
    
    
return 0;
}

这段代码的思路如下:

  1. 首先,程序通过scanf函数从用户输入中读取一个整数n
  2. 初始化一个变量d为1。
  3. 使用一个for循环,从1迭代到n-1
    • 在每次迭代中,d的值首先增加1(d=d+1;),然后乘以2(d*=2;)。
  4. 循环结束后,输出变量d的值。
  5. 程序返回0,正常结束。

但是,这段代码有一个明显的逻辑错误。在for循环中,d=d+1;d*=2;的顺序颠倒了。正确的顺序应该是先乘以2,然后再加1。否则,由于乘法的优先级高于加法,实际的计算结果将与预期不符。

这段修正后的代码会根据用户输入的n值,计算并输出一个特定的数列值。

相关推荐
海琴烟Sunshine2 小时前
leetcode 383. 赎金信 python
python·算法·leetcode
say_fall3 小时前
C语言编程实战:每日刷题 - day2
c语言·开发语言·学习
上去我就QWER4 小时前
Qt快捷键“魔法师”:QKeySequence
开发语言·c++·qt
将编程培养成爱好7 小时前
C++ 设计模式《外卖骑手状态系统》
c++·ui·设计模式·状态模式
猿太极7 小时前
设计模式学习(3)-行为型模式
c++·设计模式
cynicme8 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员8 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称9 小时前
【递归】二进制字符串中的第K位
c++·算法
mjhcsp9 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛9 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法