C++知识点总结(22):模拟算法真题 ★★★★★《开心的小红》

一、审题

题目描述

小红上高中了。她在自己的妈妈的魔鬼训练下,成为了一个学霸,每次参加一次数学比赛必拿满分。每次她拿到一个满分后就很开心。假设小红不会因为其它事开心,并且她会持续开心T 天(包含获奖当天,就算在开心的时候再次拿到满分,她也只能维持开心包括这次拿奖之日起 T T T 天,而不是额外增加 T T T 天的开心时间,除非之后再拿奖)。请你帮忙检查一下小红接下来的的日程安排,要参加 n n n 场比赛,看看接下来的几天,小红会累计开心多久?

输入描述

第一行两个整数 n n n 和 T T T。接下来一行, n n n 个单调递增整数 t i t_i ti,表示她在第 t i t_i ti​ 天的时候拿了一个满分。

输出描述

一个整数表示,小红累计开心多久。

样例1

输入

复制代码
3 5
1 2 10

输出

复制代码
11

提示

对于 100 % 100\% 100% 的数据,保证:
1 ≤ n ≤ 1 × 1 0 4 1≤n≤1\times10^4 1≤n≤1×104
1 ≤ T ≤ 32767 1≤T≤32767 1≤T≤32767
1 ≤ t i ≤ 32767 1≤t_i≤32767 1≤ti≤32767

二、思路

主要说一下计算时间的方法:

  • 判断是否拿奖日期间隔大于等于 T T T
  • 如果上面的条件成立,那么拿奖当天及接下来的 T T T 天都是开心的
  • 否则拿奖当天及接下来的开心时长为拿奖日期间隔

三、参考答案

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

int main()
{
    int n, T;
    int total = 0;
    int ti[10005] = {};
    
    cin >> n >> T;
    for (int i = 1; i <= n; i++)
    {
        cin >> ti[i];
        if (i == 1 || ti[i] - ti[i-1] >= T)
        {
            total += T;
        }
        else
        {
            total += ti[i] - ti[i-1];
        }
    }
    
    cout << total;
    return 0;
}
相关推荐
_风满楼7 小时前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法
pq2177 小时前
java实现遗传算法
算法
杨凯凡7 小时前
【032】排查入门:jstack、heap dump、Arthas 初识
java·开发语言·后端
其实防守也摸鱼7 小时前
无线网络安全--实验 规避WLAN验证之发现隐藏的SSID
java·开发语言·网络·安全·web安全·智能路由器·无线网络安全
l1t7 小时前
astral-sh发布的musl和gnu版本standalone python 性能比较
开发语言·python
木井巳8 小时前
【递归算法】单词搜索
java·算法·leetcode·决策树·深度优先
阿豪只会阿巴8 小时前
【没事学点啥】TurboBlog轻量级个人博客项目——Turbo Blog 项目学习与上线指南
开发语言·python·学习·状态模式
L-影8 小时前
常见的 ORM 工具
开发语言·数据库·fastapi·orm
咚咚王者9 小时前
人工智能之RAG工程 第一章 RAG 基础与前置知识
人工智能·算法
handler019 小时前
【算法模板】最小生成树:稠密图选 Prim,稀疏图选 Kruskal
c语言·数据结构·c++·算法