《B3923 [GESP202312 二级] 小杨做题》

题目背景

对应的选择、判断题:https://ti.luogu.com.cn/problemset/1134

题目描述

为了准备考试,小杨每天都要做题。第 1 天,小杨做了 a 道题;第 2 天,小杨做了 b 道题;从第 3 天起,小杨每天做的题目数量是前两天的总和。

此外,小杨还规定,当自己某一天做了大于或等于 m 题时,接下来的所有日子里,他就再也不做题了。

请问,到了第 N 天,小杨总共做了多少题呢?

输入格式

总共 4 行。第一行一个整数 a,第二行一个整数 b,第三行一个整数 m,第四行一个整数 N。

保证 0≤a,b≤10;a,b<m<1,000,000;3≤N≤364。

输出格式

一行一个整数,表示小杨 N 天里总共做了多少题目。

输入输出样例

输入 #1复制

复制代码
1
2
10
5

输出 #1复制

复制代码
19

输入 #2复制

复制代码
1
1
5
8

输出 #2复制

复制代码
12

说明/提示

样例解释 1

小杨第一天做 1 题,第二天做 2 题,第三天做 1+2=3 题,第四天做 2+3=5 题,第五天做 3+5=8 题。因此他总共做了 1+2+3+5+8=19 题。

样例解释 2

小杨前 5 天分别做了 1,1,2,3,5 题,由于第 5 天小杨做了 5 题,而 m=5,于是小杨从此以后不再做题。因此小杨总共做了 1+1+2+3+5=12 题。

代码实现:

cpp 复制代码
#include <iostream>
using namespace std;

int main() {
    int a, b, m, N;
    cin >> a >> b >> m >> N;
    int sum = a + b;
    int x = a, y = b;
    int cnt = 2;
    bool stop = false;
    
    while (cnt < N && !stop) {
        int now = x + y;
        cnt++;
        sum += now;
        if (now >= m) {
            stop = true;
        }
        x = y;
        y = now;
    }
    
    cout << sum << endl;
    return 0;
}
相关推荐
lzjava20246 分钟前
Python的函数
开发语言·python
Awesome Baron39 分钟前
skill、tool calling、MCP区别
开发语言·人工智能·python
Python私教1 小时前
GenericAgent PySide6 桌面应用深度解析:悬浮按钮 + 聊天面板的原生 Qt 方案
开发语言·数据库·qt
矢志航天的阿洪1 小时前
用 MATLAB 控制 STK Aviator:从零搭建一个 AWACS 支援作战场景
开发语言·matlab
澈2071 小时前
STL迭代器:容器遍历的万能钥匙
开发语言·c++
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
geovindu2 小时前
go: Strategy Pattern
开发语言·设计模式·golang·策略模式
27669582922 小时前
阿里最新acw_sc__v2 分析
开发语言·python·acw_sc__v2·acw_sc__v2逆向·acw_sc__v2算法·acw_sc__v2算法分析·cookie逆向
dog2502 小时前
圆锥曲线和二次曲线
开发语言·网络·人工智能·算法·php
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试