求助
题目描述健忘的小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也行 以下是一个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,最后输出这两个整数。 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]