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值,计算并输出一个特定的数列值。

相关推荐
To_OC26 分钟前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与5 小时前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
博客18008 小时前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴10 小时前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
复杂网络10 小时前
论最小 Agent 计算机的形态
算法
kisshyshy1 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
众少成多积小致巨1 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
猿人谷1 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络1 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络1 天前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法