栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

蓝桥杯:连续正整数的和

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

蓝桥杯:连续正整数的和

问题描述

  78这个数可以表示为连续正整数的和,1+2+3,18+19+20+21,25+26+27。
  输入一个正整数 n(<=10000)
  输出 m 行(n有m种表示法),每行是两个正整数a,b,表示a+(a+1)+...+b=n。
  对于多种表示法,a小的方案先输出。

样例输入

78

样例输出

1 12
18 21
25 27

#include
#include

using namespace std;


int main() {
	int n;
	cin >> n;
	int sum = 0;
	vector > v1;
	for (int i = 1; i <= n / 2; i++) {
		vector v;
		sum = i;
		for (int j = i + 1; j <= (n / 2) + 1; j++) {
			sum += j;
			if (sum == n) {
				v.push_back(i);
				v.push_back(j);
				v1.push_back(v);
				break;
			}
			if (sum > n) {
				break;
			}
		}
	}

	for (int i = 0; i < v1.size(); i++) {
		for (int j = 0; j < 2; j++) {
			cout << v1[i][j] << "  ";
		}
		cout << endl;
	}

}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/588461.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号