news 2026/4/14 14:30:10

AtCoder Beginner Contest竞赛题解 | 洛谷 AT_abc435_b No-Divisible Range

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
AtCoder Beginner Contest竞赛题解 | 洛谷 AT_abc435_b No-Divisible Range

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:AtCoder Beginner Contest竞赛题解 | 汇总


【题目来源】

洛谷:[AT_abc435_b ABC435B] No-Divisible Range - 洛谷

【题目描述】

You are given a sequence of positive integers $ A=(A_1,A_2,\ldots,A_N) $ of length $ N $ .
Find the number of pairs of integers $ (l,r) $ satisfying $ 1\leq l\leq r\leq N $ that satisfy the following condition:

For every integer $ i $ satisfying $ l\leq i\leq r $ , $ A_i $ isnota divisor of $ A_l+A_{l+1}+\cdots+A_r $ .

【输入】

The input is given from Standard Input in the following format:

$ N $ $ A_1 $ $ A_2 $ $ \ldots $ $ A_N $

【输出】

Output the answer.

【输入样例】

5 8 6 10 5 7

【输出样例】

6

【算法标签】

《洛谷 AT_abc435_b No-Divisible Range》 #枚举#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=55;// 最大数组长度intn;// 数组长度intans;// 答案:符合条件的区间数量inta[N];// 原始数组intsa[N];// 前缀和数组,sa[i]=a[1]+a[2]+...+a[i]/** * 检查区间[l,r]的和是否能被区间内任意一个数整除 * @param res 区间和 * @param l 区间左端点 * @param r 区间右端点 * @return 如果区间和不能被区间内任意数整除,返回true;否则返回false */boolcheck(intres,intl,intr){// 遍历区间[l,r]内的每个数for(inti=l;i<=r;i++){// 如果区间和能被a[i]整除,则不符合条件if(res%a[i]==0){returnfalse;}}// 区间和不能被区间内任意数整除returntrue;}intmain(){// 输入数组长度cin>>n;// 输入数组并计算前缀和for(inti=1;i<=n;i++){cin>>a[i];sa[i]=sa[i-1]+a[i];// 前缀和}// 枚举所有区间[i,j]for(inti=1;i<=n;i++){for(intj=i;j<=n;j++){// 计算区间[i,j]的和inttot=sa[j]-sa[i-1];// 调试输出// cout << "tot " << tot << endl;// 检查区间和是否能被区间内任意数整除if(!check(tot,i,j)){continue;// 不符合条件,跳过}// 调试输出// cout << "i j " << i << " " << j << endl;// 符合条件,计数加1ans++;}}// 输出结果cout<<ans<<endl;return0;}

【运行结果】

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

9、Windows 多媒体与图像操作全攻略

Windows 多媒体与图像操作全攻略 在 Windows 系统中,我们可以方便地对图像和多媒体进行各种操作,下面为你详细介绍相关的操作方法。 1. 查看图像 在 Windows 系统里,有两种查看图片库中图像的方法: - 使用文件资源管理器 : 1. 在文件资源管理器中,打开包含你要查看…

作者头像 李华
网站建设 2026/4/13 23:02:29

7、电脑媒体使用与文件操作全攻略

电脑媒体使用与文件操作全攻略 1. 连接电脑与家庭影院 要将电脑与电视和音响系统连接,需借助合适的硬件,之后就能通过媒体中心程序在电视上播放 DVD 和图片,在音响上播放音乐,部分情况下还能连接电视线缆在电脑上观看和录制电视节目。 - 电视连接 :若要在电视上观看电…

作者头像 李华
网站建设 2026/4/3 15:17:16

11、互联网冲浪与邮件使用全指南

互联网冲浪与邮件使用全指南 1. 启动 Internet Explorer 若要使用 Windows 7 内置的 Internet Explorer 浏览器浏览网页,首先需启动它。以下是具体步骤: 1. 连接到互联网。 2. 点击 Internet Explorer。若任务栏中没有该图标,可点击“开始”,再点击“所有程序”,最后点…

作者头像 李华
网站建设 2026/4/7 22:55:43

14、Windows 7 系统安全与个性化设置全攻略

Windows 7 系统安全与个性化设置全攻略 1. Windows 7 系统安全设置 1.1 账户密码保护 在 Windows 7 系统中,为保障账户安全,可使用密码保护用户账户。若不设置密码,其他用户在欢迎屏幕点击你的用户名即可登录。为实现最高安全级别,需创建一个难以猜测和破解的强密码。 …

作者头像 李华
网站建设 2026/4/13 6:06:54

16、Windows 7 系统维护全攻略

Windows 7 系统维护全攻略 在使用 Windows 7 系统的过程中,为了确保系统的稳定运行和高效性能,我们需要进行一系列的系统维护操作。下面将为你详细介绍各项维护操作的具体内容和步骤。 1. 删除不必要的文件 为了释放计算机硬盘空间并保持 Windows 7 高效运行,可以使用磁盘…

作者头像 李华
网站建设 2026/4/8 15:28:28

Excalidraw支持多语言吗?中文适配情况说明

Excalidraw 的多语言支持与中文适配深度解析 在远程协作日益成为常态的今天&#xff0c;可视化工具早已不再是设计师的专属武器。从产品原型讨论到系统架构设计&#xff0c;越来越多的技术团队依赖像 Excalidraw 这样的轻量级白板工具来快速表达和共享想法。它那标志性的“手绘…

作者头像 李华