刘子诺 发表于 2023-3-17 21:59:28

求助

题目描述
健忘的小z忘了自己的电脑密码,好在他设置了密码提示问题。回答出提示问题即可找回密码。

提示问题为:

1.找出一个大于等于L,小于等于D的最小整数N,N的各个位加起来结果是X

2.找出一个大于等于L,小于等于D的最大整数M,M的各个位加起来结果是X

问题保证N和M一定存在。

可怜的小z并不能想出这个问题,你能帮他吗?

输入格式
第一行是一整数L,第二行是一个整数D,第三行是一个整数X

输出格式
第一行输出整数N,第二行输出整数M

样例
输入#1
100
500
12
输出#1
129
480

谁能用C++做一下,谢谢,C也行

isdkz 发表于 2023-3-17 22:01:50

以下是一个C++的解决方案:

#include <iostream>

int sum_of_digits(int num) {
    int sum = 0;
    while (num != 0) {
      sum += num % 10;
      num /= 10;
    }
    return sum;
}

int main() {
    int L, D, X;
    std::cin >> L >> D >> X;

    int N = L;
    while (sum_of_digits(N) != X) {
      N++;
    }

    int M = D;
    while (sum_of_digits(M) != X) {
      M--;
    }

    std::cout << N << std::endl;
    std::cout << M << std::endl;

    return 0;
}

这个程序首先定义了一个sum_of_digits()函数来计算一个整数的各个位数之和。

在main()函数中,程序从输入读取L、D和X,然后找到满足条件的最小整数N和最大整数M,最后输出这两个整数。

傻眼貓咪 发表于 2023-3-18 13:51:38

C++#include <iostream>
using namespace std;

// 用来判断 N 的各个位加起来结果是否是 X
bool f(int num, int X) {
        int sum = 0;
        while (num) {
                sum += num % 10;
                num /= 10;
        }
        return sum == X;
}

int main(void) {
        int L, D, X;
        cin >> L >> D >> X;

        // 打印 N
        for (int num = L; num <= D; ++num) {
                if (f(num, X)) {
                        cout << num << endl;
                        break;
                }
        // 打印 M
        for (int num = D; num >= L; --num) {
                if (f(num, X)) {
                        cout << num << endl;
                        break;
                }
        }

        return 0;
}
PythonL, D, X = map(int, (input(), input(), input()))
f = lambda num, x: sum(map(int, iter(str(num)))) == x
N = min()
M = max()
print(N, M, sep = '\n')
页: [1]
查看完整版本: 求助