当前位置: 首页 > 图灵资讯 > 技术篇> 试题 基础练习 序列求和

试题 基础练习 序列求和

来源:图灵教育
时间:2023-05-09 10:10:24

  资源限制

  内存限制:256.0MB C/C++时限:1.0s Java时间限制:3.0s Python时限:5.0s

  问题描述

  求1+2+3+...+n的值。

  输入格式

  输入包括一个整数n。

  输出格式

  一行输出,包括一个整数,表示1+2+3+...+n的值。

  样例输入

  4

  样例输出

  10

  样例输入

  100

  注:有些试题会给出多组样例输入输出,以帮助您更好地做题。

  一般来说,这些样本都需要在提交前通过测试,但这并不意味着这些样本数据是正确的。你的程序是完全正确的。潜在的错误仍然可能导致你的低分。

  样例输出

  5050

  数据规模和协议

  1 <= n <= 1,000,000,000。

  注:请注意这里的数据规模。

  这个问题的直接想法是直接使用一个循环来积累。然而,当数据规模较大时,这种“暴力”方法往往会导致加班。此时,您需要考虑其他方法。你可以试试。如果您使用1万个程序作为您的程序输入,您的程序是否可以在上述规定的期限内运行。

  这个问题的另一个值得注意的是,答案的大小不是你语言默认的整形手术(int)在范围内,如果使用整形手术来保存结果,就会导致结果错误。

  如果你使用C++或C语言并准备使用printf输出结果,你的格式字符串应该写成%I64d输出long long类型的整数。

  上代码:import java.util.Scanner; public class Main { public static void main(String[] args) {// TODO Auto-generated method stubScanner sc=new Scanner(System.in);int n=sc.nextInt();long num=0;for(int i=1;i<=n;i++) {num=num+i;}System.out.println(num);} }