news 2026/3/24 12:25:41

打卡信奥刷题(2520)用C++实现信奥 P1982 [NOIP 2013 普及组] 小朋友的数字

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2520)用C++实现信奥 P1982 [NOIP 2013 普及组] 小朋友的数字

P1982 [NOIP 2013 普及组] 小朋友的数字

题目背景

NOIP2013 普及组 T3

题目描述

nnn个小朋友排成一列。每个小朋友手上都有一个数字,这个数字可正可负。规定每个小朋友的特征值等于排在他前面(包括他本人)的小朋友中连续若干个(最少有一个)小朋友手上的数字之和的最大值。

作为这些小朋友的老师,你需要给每个小朋友一个分数,分数是这样规定的:第一个小朋友的分数是他的特征值,其它小朋友的分数为排在他前面的所有小朋友中(不包括他本人),小朋友分数加上其特征值的最大值。

请计算所有小朋友分数的最大值,输出时保持最大值的符号,将其绝对值对ppp取模后输出。

输入格式

第一行包含两个正整数n,pn,pn,p,之间用一个空格隔开。

第二行包含nnn个数,每两个整数之间用一个空格隔开,表示每个小朋友手上的数字。

输出格式

一个整数,表示最大分数对ppp取模的结果。

输入输出样例 #1

输入 #1

5 997 1 2 3 4 5

输出 #1

21

输入输出样例 #2

输入 #2

5 7 -1 -1 -1 -1 -1

输出 #2

-1

说明/提示

样例解释 1

小朋友的特征值分别为1,3,6,10,151,3,6,10,151,3,6,10,15,分数分别为 $ 1,2,5,11,21$,最大值212121997997997的模是212121

样例解释 2

小朋友的特征值分别为−1,−1,−1,−1,−1-1,-1,-1,-1,-11,1,1,1,1,分数分别为−1,−2,−2,−2,−2-1,-2,-2,-2,-21,2,2,2,2,最大值−1-11777的模为−1-11,输出−1-11

【数据范围】

对于50%50\%50%的数据,1≤n≤10001 \le n \le 10001n10001≤p≤10001 \le p \le 10001p1000,所有数字的绝对值不超过100010001000

对于100%100\%100%的数据,1≤n≤1061 \le n \le {10}^61n1061≤p≤1091 \le p \le {10}^91p109,其他数字的绝对值均不超过109{10}^9109

C++实现

#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong#define_read<int>()template<classT>inlineTread(){T r=0,f=1;charc=getchar();while(!isdigit(c)){if(c=='-')f=-1;c=getchar();}while(isdigit(c))r=(r<<1)+(r<<3)+(c^48),c=getchar();returnf*r;}inlinevoidout(intx){if(x<0)putchar('-'),x=-x;if(x<10)putchar(x+'0');elseout(x/10),putchar(x%10+'0');}constintN=1e6+10,K=1e9+100;inta[N];intb[N],c[N];signedmain(){intn,mod;n=_,mod=_;for(inti=1;i<=n;i++)a[i]=_;intmax=-2*1e15,sum=0;for(inti=1;i<=n;i++){sum+=a[i];max=max>sum?max:sum;b[i]=max;if(sum<0)sum=0;}c[1]=b[1];c[2]=b[1]+b[1];boolf=0;for(inti=3;i<=n;i++){if(b[i-1]>0)c[i]=c[i-1]+b[i-1];elsec[i]=c[i-1];if(c[i]>K)f=1,c[i]%=mod;}if(f){out(c[n]%mod);putchar('\n');}elseout((c[1]>c[n]?c[1]:c[n])%mod);return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 8:03:48

Dify与Spring AI集成难题一网打尽,资深架构师亲授生产级解决方案

第一章&#xff1a;Dify与Spring AI集成概述Dify 作为一款面向 AI 应用开发的低代码平台&#xff0c;提供了可视化编排、模型管理与 API 服务发布能力。Spring AI 是 Spring 生态中用于简化人工智能应用开发的框架&#xff0c;支持与主流大模型平台对接。将 Dify 与 Spring AI …

作者头像 李华
网站建设 2026/3/20 1:17:47

学习笔记——Makefile

基本概念 Makefile 是工程管理工具&#xff0c;用于编译多个源文件&#xff08;可能在不同目录下&#xff09;&#xff0c;可以添加编译选项。 基本语法规则 makefile 目标: 依赖 [TAB] 规则命令 版本演进 版本1&#xff1a;直接编译 makefile a.out: main.c func.cgcc…

作者头像 李华
网站建设 2026/3/14 2:26:34

【必看收藏】2026大模型校招趋势:5.2W月薪岗位揭秘,AI人才就业指南

2026年AI人才校招市场呈现显著扩张趋势&#xff0c;大模型算法岗位月薪可达5.2万&#xff0c;顶尖人才薪资翻倍。高科技企业(60%)比金融行业(40.1%)更重视AI人才&#xff0c;近六成企业计划扩招。企业更看重数学与算法基础(60.3%)和项目实践(52.5%)&#xff0c;名校学历重要性下…

作者头像 李华
网站建设 2026/3/14 9:07:02

MMSA框架:多模态情感分析的终极指南与实战应用

MMSA框架&#xff1a;多模态情感分析的终极指南与实战应用 【免费下载链接】MMSA MMSA is a unified framework for Multimodal Sentiment Analysis. 项目地址: https://gitcode.com/gh_mirrors/mm/MMSA 在人工智能快速发展的今天&#xff0c;多模态情感分析正成为理解人…

作者头像 李华
网站建设 2026/3/22 11:49:46

Markdowner:网站内容秒变AI友好Markdown的终极神器

还在为网站内容整理发愁吗&#xff1f;Markdowner来帮你&#xff01;这个强大的开源工具能够将任何网站瞬间转换为适合大型语言模型处理的Markdown格式数据&#xff0c;让你的AI应用更智能、更高效。 【免费下载链接】markdowner A fast tool to convert any website into LLM-…

作者头像 李华
网站建设 2026/3/23 20:24:37

如何扛住《珠江》所有拍摄考验?幕后8K设备实力揭晓

珠江&#xff0c;一条承载着千年商贸与人文记忆的水道&#xff0c;其纪录片拍摄始终面临着独特挑战——变幻的光线、复杂的水汽环境、需要同时捕捉的宏大场景与精微细节。当拍摄团队决定采用博冠8K摄像机完成这一项目时&#xff0c;这既是对设备性能的一次高强度检验&#xff0…

作者头像 李华