【编程练习】求和

[编程|20分] 求和

时间限制:C/C++ 1秒,其他语言 2秒
空间限制:C/C++ 32768K,其他语言 65536K
64bit IO Format: %lld
本题可使用本地IDE编码,不做跳出限制,编码后请点击“保存并调试”按钮进行代码提交。


题目描述

输入两个整数 n 和 m,从数列1,2,3…….n 中随意取几个数,使其和等于 m ,要求将其中所有的可能组合列出来

输入描述:

每个测试输入包含2个整数,n和m

输出描述:

按每个组合的字典序排列输出,每行输出一种组合

示例1

输入
5 5

输出
1 4
2 3
5

暴力求解法

测试通过率仅为 66%

#include<stdio.h>
#include<iostream>

using namespace std;

int main(){
    int n, m;
    cin >> n;
    cin >> m;
    if(n == 0)
        return 0;
    if(m == 0)
        return 0;
    if (m<n){
        n = m;
    }
    for (size_t i = 1; i < n + 1; ++i){
        for (size_t j = i; j < n + 1; ++j){
            if (i + j == m)
                cout << i << " " << j << endl;
        }
    }
    cout << m << endl;
    return 0;
}

猜你喜欢

转载自blog.csdn.net/sofia_m/article/details/81133355
今日推荐