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

相关推荐
啊森要自信11 分钟前
CANN ops-cv:AI 硬件端视觉算法推理训练的算子性能调优与实战应用详解
人工智能·算法·cann
czy878747518 分钟前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
我在人间贩卖青春27 分钟前
C++之继承的方式
c++·private·public·protected·继承方式
仟濹34 分钟前
算法打卡day2 (2026-02-07 周五) | 算法: DFS | 3_卡码网99_计数孤岛_DFS
算法·深度优先
驭渊的小故事37 分钟前
简单模板笔记
数据结构·笔记·算法
YuTaoShao1 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头1 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
goodluckyaa1 小时前
LCR 006. 两数之和 II - 输入有序数组
算法
孤狼warrior1 小时前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
Σίσυφος19002 小时前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面