题目链接
题目描述
计算从 1 到一个给定的正整数 n
的所有自然数之和。
即计算:1 + 2 + 3 + ... + n
输入描述:
输入一个正整数 n
(1 ≤ n ≤ 1,000,000,000)。
输出描述:
输出一个整数,表示从 1 到 n
的自然数之和。
解题思路
本题要求计算一个等差数列的和。
方法一:循环(不推荐)
最直观的方法是使用一个循环,从 1 累加到 n
。但题目的数据范围 n
高达 10^9,直接循环会导致程序运行时间过长,从而超时(Time Limit Exceeded)。
方法二:高斯求和公式(推荐)
这是一个著名的数学问题,其最优解是使用等差数列求和公式(也称高斯求和公式):
Sum = n * (n + 1) / 2
这个公式可以在常数时间内计算出结果,非常高效。
关键点:数据类型
由于 n
的最大值是 10^9,n * (n + 1)
的结果会大约是 10^18,这个值会超出标准 32 位整型 (int
) 的最大范围(约 2 * 10^9),导致数据溢出。因此,在计算和存储结果时,必须使用 64 位整型(C++中的 long long
,Java中的 long
)来避免错误。
代码
#include <iostream>
using namespace std;
int main() {
// 使用 long long 来防止 n * (n + 1) 的计算结果溢出
long long n;
cin >> n;
// 应用高斯求和公式
long long sum = n * (n + 1) / 2;
cout << sum << endl;
return 0;
}
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
// 使用 long 来防止 n * (n + 1) 的计算结果溢出
long n = sc.nextLong();
// 应用高斯求和公式
long sum = n * (n + 1) / 2;
System.out.println(sum);
}
}
# Python 的 int 类型可以自动处理大整数,无需担心溢出
n = int(input())
# 应用高斯求和公式
# 使用 // 保证整数除法
sum_val = n * (n + 1) // 2
print(sum_val)
算法及复杂度
- 算法:高斯求和公式。
- 时间复杂度:
- 这是一个直接的数学计算,与
n
的大小无关。 - 空间复杂度:
- 仅需常数空间存储变量。