鱼C论坛

 找回密码
 立即注册
查看: 2414|回复: 2

求助

[复制链接]
发表于 2023-3-17 21:59:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述
健忘的小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也行
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-3-17 22:01:50 | 显示全部楼层
以下是一个C++的解决方案:

  1. #include <iostream>

  2. int sum_of_digits(int num) {
  3.     int sum = 0;
  4.     while (num != 0) {
  5.         sum += num % 10;
  6.         num /= 10;
  7.     }
  8.     return sum;
  9. }

  10. int main() {
  11.     int L, D, X;
  12.     std::cin >> L >> D >> X;

  13.     int N = L;
  14.     while (sum_of_digits(N) != X) {
  15.         N++;
  16.     }

  17.     int M = D;
  18.     while (sum_of_digits(M) != X) {
  19.         M--;
  20.     }

  21.     std::cout << N << std::endl;
  22.     std::cout << M << std::endl;

  23.     return 0;
  24. }
复制代码


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

在main()函数中,程序从输入读取L、D和X,然后找到满足条件的最小整数N和最大整数M,最后输出这两个整数。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-18 13:51:38 | 显示全部楼层
C++
  1. #include <iostream>
  2. using namespace std;

  3. // 用来判断 N 的各个位加起来结果是否是 X
  4. bool f(int num, int X) {
  5.         int sum = 0;
  6.         while (num) {
  7.                 sum += num % 10;
  8.                 num /= 10;
  9.         }
  10.         return sum == X;
  11. }

  12. int main(void) {
  13.         int L, D, X;
  14.         cin >> L >> D >> X;

  15.         // 打印 N
  16.         for (int num = L; num <= D; ++num) {
  17.                 if (f(num, X)) {
  18.                         cout << num << endl;
  19.                         break;
  20.                 }
  21.         // 打印 M
  22.         for (int num = D; num >= L; --num) {
  23.                 if (f(num, X)) {
  24.                         cout << num << endl;
  25.                         break;
  26.                 }
  27.         }

  28.         return 0;
  29. }
复制代码

Python
  1. L, D, X = map(int, (input(), input(), input()))
  2. f = lambda num, x: sum(map(int, iter(str(num)))) == x
  3. N = min([num for num in range(L, D + 1) if f(num, X)])
  4. M = max([num for num in range(L, D + 1) if f(num, X)])
  5. print(N, M, sep = '\n')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-11 15:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表