当前位置: 首页 > news >正文

山东大学考研机试题——整数序列

题目描述

传送门——AcWing 3717. 整数序列 - AcWing

很多整数可以由一段连续的正整数序列(至少两个数)相加而成,比如 25=3+4+5+6+7=12+1325=3+4+5+6+7=12+13。

输入一个整数 N,输出 N 的全部正整数序列,如果没有则输出 NONE

输入格式

一个整数 N。

输出格式

  • 每行输出一个满足条件的整数序列。

  • 序列内部元素从小到大排序。

  • 优先输出首项更小的序列。

数据范围

2 ≤ N ≤ 107

输入样例:

25

输出样例:

3 4 5 6 7
12 13

思路及代码

二分查找

从 1 ~ n / 2 遍历 i,通过二分查找以 i 开头时的答案。

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N = 1e7+7;
int n;
int main(){std::ios::sync_with_stdio(false);std::cin.tie(0);std::cout.tie(0);cin>>n;LL k = n / 2;bool tag = false;for(LL i=1;i<=k;i++){// high = k + 1作为最大值是因为当最大值大于 n/2时,由于要求是一组连续的数,所以此时的序列至多有2个数LL low = i, high = k + 1;while(low < high){LL mid = low + high + 1 >> 1;if((mid - i + 1)*(i + mid) <= 2*n){low = mid;}else{high = mid -1;}}if((low - i + 1)*(i + low) == 2*n){tag = true;for(int j=i;j<=low;j++){cout<<j<<" ";}cout<<"\n";}}if(tag == false){cout<<"NONE";}return 0;
}

数学公式

该题本质考察的是一组连续数的和,则令这组连续数的开头是a,共k个数,那么这组数的和通过求和公式可得为 (a + a + k - 1) * k / 2。而我们需要求得是 a 和 k,当这两个未知数确定后,一组数便确定了。

因此考虑, (a + a + k - 1) * k / 2 = n,即 (2a + k - 1) * k = 2n,可知,由 a 和 k 组成的 y = (2a + k - 1) 和 x = k 两个公式是 2n 的因子。既然如此,我们可以去求 2n 的因子,考察满足条件的两个因子 x和y,由 x和y 可得到 a 和 k。

#include<bits/stdc++.h>
using namespace std;
int main() {std::ios::sync_with_stdio(false);std::cin.tie(0);std::cout.tie(0);int n;cin >> n;n *= 2;int cnt = 0;// 题目要求优先输出首项更小的序列,即 (2a + k - 1) * k 中的 a 更小。由 (2a + k - 1) * k = 2n 可知 k 越大 a越小,即因子 x 越大,a越小,所以这里 x 从大到小遍历 for (int x = sqrt(n); x > 1; x--) {if (n % x == 0) {int y = n / x;int t = y - (x - 1);// t = 2a,因此 t 必须是偶数if (t % 2 == 0) {cnt++;int a = t / 2;for (int i = a; i < a + x; i++) {cout << i << " ";}cout << "\n";}}}if (cnt == 0) {cout << "NONE";}return 0;
}

http://www.lryc.cn/news/415317.html

相关文章:

  • 一口酒一口水,不宜喝醉
  • AI6-PPOCRLabel带GPU训练
  • Unity四元数线性插值Lerp
  • Makefile 语法
  • 【运维项目经历|039】Ceph高性能云存储集群部署与优化
  • 算法刷题之哈希表
  • 【linux】linux中定时任务的巧妙运用,让你轻松解放双手
  • 【复旦微FM33 MCU 外设开发指南】系统篇——时钟
  • Android Graphics 显示系统 - 计算FPS的原理与探秘Present Fence
  • 图论:1857. 有向图中最大颜色值(拓扑排序+动态规划)
  • pytorch学习笔记3 tensor索引和切片
  • 学习记录——day23 多进程编程
  • 英特尔股市暴跌,财报亏损 | HuggingFace 实现盈利 |iOS18 Beta 苹果AI
  • C++入门基础(二)
  • fabricjs 实现图像的二值化功能
  • 修改本地hosts文件及外部访问机器本地hosts文件后,rancher UI网站仍然不能访问
  • 西北潮榆林范儿,新榆林首个360°沉浸式剧场发布会闪耀亮相
  • 如何创建响应式移动端网页设计?最佳实践详解
  • Python 如何进行Web抓取(BeautifulSoup, Scrapy)
  • 白骑士的PyCharm教学进阶篇 2.5 数据库连接与管理
  • (五)activiti-modeler 编辑器初步优化
  • (学习总结12)C++类和对象3
  • docxtpl,一个强大的 Python 库!
  • 捷途山海T2:超长续航,节能环保的驾驶新星
  • [Day 45] 區塊鏈與人工智能的聯動應用:理論、技術與實踐
  • 白骑士的PyCharm教学实战项目篇 4.3 自动化测试与持续集成
  • 权限模块开发+权限与角色关联(完整CRUD)
  • llama神经网络的结构,llama-3-8b.layers=32 llama-3-70b.layers=80; 2000汉字举例说明
  • 单细胞数据怎么表现genes mRNA表达的热图?
  • Java聚合快递对接云洋系统小程序源码