0
点赞
收藏
分享

微信扫一扫

PAT 乙级 1056 组合数的和 (15 分)

桑二小姐 2022-02-26 阅读 67

给定 N 个非 0 的个位数字,用其中任意 2 个数字都可以组合成 1 个 2 位的数字。要求所有可能组合出来的 2 位数字的和。例如给定 2、5、8,则可以组合出:25、28、52、58、82、85,它们的和为330。

输入格式:

输入在一行中先给出 N(1 < N < 10),随后给出 N 个不同的非 0 个位数字。数字间以空格分隔。

输出格式:

输出所有可能组合出来的2位数字的和。

输入样例:

3 2 8 5

输出样例:

330

分析:

暴力算法哈哈哈。

代码:

#include <iostream>
#include <vector>

using namespace std;

int main() {
    int N, t;
    scanf("%d", &N);
    long long sum = 0;
    vector<int> vec(N);
    for (int i = 0; i < N; i++)
        scanf("%d", &vec[i]);
    
    int len = vec.size();
    for (int i = 0; i < len; i++) {
        for (int j = 0; j < len; j++) {
            if (i != j) {
                int temp = vec[i] * 10 + vec[j];
                sum += temp;
            }
        }
    }

    printf("%lld\n", sum);

    return 0;
}
举报

相关推荐

0 条评论