偶数求和

GESP一级综合基础练习,涉及循环和基本运算,适合初学者起步练习,难度★☆☆☆☆。

bcqm-3154

题目要求

题目描述

输入 nn 个整数,求出其中所有偶数的和。

输入格式

输入第一行一个一个整数 n(1n105)n(1≤n≤105) 表示数的个数。

接下来一行 nn 个 int 范围内的整数。

输出格式

一个整数,表示这些数的和

样例输入 #1

5
1 4 2 7 8

样例输出 #1

14

题目分析

这道题目的解题思路比较简单:

  1. 首先读入一个整数 nn,表示要输入的数字个数
  2. 然后循环读入 nn 个整数,对每个整数判断:
    • 如果是偶数(能被2整除),就将其加入到总和中
    • 如果是奇数则跳过
  3. 最后输出所有偶数的和

需要注意的点:

  • 由于输入数据范围较大(n105)(n≤10^5),且每个数都在int范围内,所以累加和需要用long long类型来存储,防止溢出
  • 判断偶数可以用取模运算 %,如果一个数除以2的余数为0,则这个数是偶数

{% include custom/custom-post-content-inner.html %}

示例代码

#include <iostream>
using namespace std;

int main() {
    // 输入数字的个数
    int a;
    cin >> a;
    
    // 用于存储每次输入的数字
    int d;
    // 用long long存储累加和,防止溢出
    long long ans = 0;
    
    // 循环读入a个数字
    for (int i = 0; i < a; i++) {
        cin >> d;
        // 如果是偶数则累加
        if (d % 2 == 0) {
            ans += d;
        }
    }
    
    // 输出结果
    cout << ans;
    return 0;
}

{% include custom/custom-post-content-footer.md %}

所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code

luogu-”系列题目可在 洛谷题库 在线评测。

bcqm-”系列题目可在 编程启蒙题库 在线评测。

GESP/CSP 认证学习微信公众号
GESP/CSP 认证学习微信公众号
Last updated on