【蓝桥杯 入门训练 序列求和】

划重点!!输出有效位数设置:引用头文件#include<iomanip>下的setprecision()

----------------------------------------------------------------------------------

试题 入门训练 序列求和

资源限制

时间限制:1.0s   内存限制:256.0MB

问题描述

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

输入格式

输入包括一个整数n。

输出格式

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

样例输入

4

样例输出

10

样例输入

100

说明:有一些试题会给出多组样例输入输出以帮助你更好的做题。

一般在提交之前所有这些样例都需要测试通过才行,但这不代表这几组样例数据都正确了你的程序就是完全正确的,潜在的错误可能仍然导致你的得分较低。

样例输出

5050

数据规模与约定

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

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

本题直接的想法是直接使用一个循环来累加,然而,当数据规模很大时,这种“暴力”的方法往往会导致超时。此时你需要想想其他方法。你可以试一试,如果使用1000000000作为你的程序的输入,你的程序是不是能在规定的上面规定的时限内运行出来。

本题另一个要值得注意的地方是答案的大小不在你的语言默认的整型(int)范围内,如果使用整型来保存结果,会导致结果错误。

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

-------------------------------------------------------------------------------------------------------

今天依然是一只仰望dalao的小菜鸡。。电脑屏一直不好用,然鹅我不能去修,疫情+要每天做题,要换屏的话最少半个月,我哭哭q^q

正题切入:

①n上限10000000000,你想啊for循环()得用多长时间。。超时OUT!!

等差数列求和,你值得拥有。。

②还是存储时考虑数的规模问题,int 32位 float 32位  double 64位存储 你选啥

③你是否为输出结果溢出(有效位数不够)而烦恼??只需#include<iostream>+cout<<setprecision(20)<<sum;

------------------------------------------------------------------------------------------------------

#include<iostream>

#include<iomanip>

using namespace std;

int main(){

double i,n;

double sum=0;

cin>>n;

sum=n*(1+n)/2;

cout<<setprecision(20)<<sum;

return 0;

}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,433评论 0 2
  • //出自51博客:www.Amanda0928.51.com 第一章 一、选择题 1.B; (typedef ,t...
    Damongggggg阅读 11,252评论 0 1
  • 7-1 求整数均值 (5分) 本题要求编写程序,计算4个整数的和与平均值。题目保证输入与输出均在整型范围内。输入格...
    往sir_b2a2阅读 3,452评论 0 0
  • 题目类型 a.C++与C差异(1-18) 1.C和C++中struct有什么区别? C没有Protection行为...
    阿面a阅读 7,734评论 0 10
  • 7-1 简单的猜数字游戏[1] (4分) 简单的猜数字游戏是预先设置一个100以内的正整数作为被猜数,用户输入一个...
    往sir_b2a2阅读 2,250评论 0 0