第十六届蓝桥杯_省赛B组(C).可分解的正整数

题目如下

首先理解题目;可以知道可分解的数字必须满足两个条件

第一:序列的长度至少为3

第二:序列中数字是递增的(相差为1)意思就是连在一起的

通过题目给的案例来理解一下:

第一个数字3 ->[-2 -1 -1 0 1 2 3]可以

第二个数字6->[-5,-4,-3,-2,-1,0,1,2,3,4,5,6]可以

可以发现两边可以构造出对称,从而可以约掉,最后仅剩需要的数字

那有没有条件不满足呢?有的兄弟有的

我们发现题目中给出的3可以,大于的也可以,所以尝试反向推导,再由于题目中的A[N]都为正整数,所以只需要推导一下1和2即可知道全部情况
2->[-1 0 1 2]满足
1->[0,1]只能通过0和1来构造,但是题目要求序列至少为3由此可得除了1之外的其他正整数都满足题目的情况

最终的解就是求出除1之外有多少个正整数

AC代码:

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cmath>
#include<climits>
using namespace std;
int main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	int N;cin>>N;
	int ans=0;
	for(int i=1;i<=N;i++){
		int x;cin>>x;
		if(x!=1) ans++;
	}
	cout<<ans;
	return 0;
} 
相关推荐
2401_858936881 小时前
【Linux C 编程】标准 IO 详解与实战:从基础接口到文件操作实战
linux·c语言
Epiphany.5562 小时前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
YuTaoShao2 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
季明洵3 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
浅念-4 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
爱吃生蚝的于勒4 小时前
【Linux】进程信号之捕捉(三)
linux·运维·服务器·c语言·数据结构·c++·学习
The森4 小时前
Linux IO 模型纵深解析 01:从 Unix 传统到 Linux 内核的 IO 第一性原理
linux·服务器·c语言·经验分享·笔记·unix
C++ 老炮儿的技术栈5 小时前
Qt 编写 TcpClient 程序 详细步骤
c语言·开发语言·数据库·c++·qt·算法
wangjialelele6 小时前
Linux下的IO操作以及ext系列文件系统
linux·运维·服务器·c语言·c++·个人开发
Ll13045252987 小时前
Leetcode二叉树part4
算法·leetcode·职场和发展