51nod 1138 连续整数的和

本文介绍了如何运用等差数列的前n项和公式来解决寻找连续整数和的问题。通过公式S = na1 + n(n-1)/2,可以推导出n的可能范围,并通过枚举序列长度n来求解首项a1。
摘要由CSDN通过智能技术生成

等差数列前n项和公式:S = na1+n(n-1)/2,a1 = (S-n(n-1)/2)/n,可以求出n的范围大概就是[2,sqrt(2*S)],枚举序列长度n,然后求解a1。

using System;
using System.IO;
using System.Numerics;

namespace timeless
{
    class Program
    {
        static void Main(string[] args)
        {
            StreamReader sr = new StreamReader(Console.OpenStandardInput());
            StreamWriter sw = new StreamWriter(Console.OpenStandardOutput());
            int n = Convert.ToInt32(sr.ReadLine());
            int len = (int)Math.Sqrt(n*2);
            bool flag = false;
            for (int i = len; i >= 2; --i)
            {
                if ((n - (i * (i - 1)) / 2) % i == 0)
                {
                    flag = true;
                    sw.WriteLine((n - (i * (i - 1)) / 2)/ i);
                }
            }
            if (!flag)
                sw.WriteLine("No Solution");
            sw.Flush();
            sw.Close();
            sr.Close();
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值