41-所有和为s的连续正数序列/递增数列中和为s的两个数字

本文介绍两种算法:一种用于找出所有和为特定数值s的连续正数序列;另一种用于在一个递增数列中找到和为s的两个数字。通过巧妙运用等差数列性质及双指针技巧实现高效求解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里用到一个等差数列公式:

     Sum=(small+big)n/2;

所有和为s的连续正数序列:

 vector<vector<int> > FindContinuousSequence(int sum)
{
	vector<int>  v;
	vector<vector<int> > vv;
	if (sum < 3) return vv;
	int small = 1;
	int big =  2;
	
	int n = 2;
	while (small<(sum+1)/2)   //注意结束条件 因为必须起码俩数,最小的要是大于和的一半了,再往后也没啥用
	{
		if((small + big)*n / 2 < sum)
		{
			n++;
			big++;
		}
		else if ((small + big)*n / 2 > sum)
		{
			n--;
			small++;
		}
		else
		{
			
			for (int i = small; i <= big;i++)
			{
				v.push_back(i);
			}
			vv.push_back(v);
			v.clear();
			big++;
			n++;

		}
	}
	return vv;

}

递增数列中和为s的两个数字:

vector<int> FindNumbersWithSum(vector<int> array,int sum) {
        	vector<int>  v;
	if (sum <=0) return v;
	int small = 0;

	int big = array.size()-1;

	while (small<big)
	{
		if (array[small] + array[big]<sum)
		{
			small++;
		}
		else if (array[small] + array[big] > sum)
		{
			big--;
		}
		else
		{
			v.push_back(array[small]);
			v.push_back(array[big]);
			break;
		}
	}
	return v;
    }



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值