算式900

题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

小明的作业本上有道思考题:

看下面的算式:

(□□□□-□□□□)*□□=900
copy
其中的小方块代表 00 ~ 99 的数字,这 1010 个方块刚好包含了 00 ~ 99 中的所有数字。 注意:00 不能作为某个数字的首位。

小明经过几天的努力,终于做出了答案!如下:

(5012-4987)*36=900
copy
用计算机搜索后,发现还有另外一个解,本题的任务就是:请你算出这另外的一个解。

注意:输出格式需要与示例严格一致; 括号及运算符号不要用中文输入法; 整个算式中不能包含空格。

运行限制
最大运行时间:1s
最大运行内存: 128M

思路:
1.找出后两位空格数,就是900大于等于10小于等于100的约数
2.设第一个数为i,第二个为j,第三个为k,
1000<i<10000,由于k的值最小为10,所以i-j最大为90,最小为10,所以
i-90<=j<=i-10,当i==5012跳过
3.将k约数求出,将三个数逐个拆分放入set集合,判断set的大小为10说明没有重复,符合条件,否则set集合清空继续.

ps:本题虽然简单,并且是填空题,但是缩小查找范围,减少时间复杂度的思想还是值得学习,如果数据量过大,循环次数过10亿很有可超时,也不能无视判断,计算的时间.

代码实现:

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        //在此输入您的代码...
        int n = 900;
        List<Integer> list = new ArrayList<>();
        //求出90的约数
        for (int i = 10; i < 100; i++) {
            if (n % i == 0) {
                list.add(i);//90的约数k
            }
        }
        //将数字存入set集合去重复
        Set set = new HashSet();
        int mod = 0, ri = 0, rj = 0, rm = 0;
        f: //跳出循环标志
        for (int i = 1000; i < 10000; i++) {
            if(i==5012) continue ;
            for (int j = i - 90; j <= i - 10; j++) {
                int y = j, x = i;//将值赋值中间变量用来逐个拆分放进set集合
                for (int m = 0; m < list.size(); m++) {
                    int k = list.get(m);
                    if( (i - j) * list.get(m) == n ) {
                        while (x != 0) {//拆分第一个数字
                            mod = x % 10;
                            x = x / 10;
                            set.add(mod);
                        }
                        while (y != 0) {//拆分第二个数字
                            mod = y % 10;
                            y = y / 10;
                            set.add(mod);
                        }
                        while (k != 0) {//拆分第三个数字
                            mod = k % 10;
                            k = k / 10;
                            set.add(mod);
                        }
                        //判断长度等于10说明没有重复数组,符合条件
                        if (set.size() == 10) {
                            ri = i;
                            rj = j;
                            rm = list.get(m);
                            break f;
                        } else {
                            set.clear();//清空set集合
                        }
                    }
                }
            }
        }
        System.out.println("(" + ri + "-" + rj + ")*" + rm + "=" + n);
        scan.close();
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch 是一个基于Python的机器学习库,它提供了许多用于开发深度学习模型的工具和算法。在算式识别中,PyTorch 可以用于训练一个神经网络模型,对输入的算式进行识别和解析。 算式识别是指将输入的数学算式转换为计算机可识别的形式,通常包括识别算式的各个元素(如数字、运算符)和确定它们之间的关系。PyTorch 可以通过使用多层的神经网络模型来实现算式识别。 首先,需要准备一个合适的训练数据集,包括正例(正确的算式)和负例(错误的算式)。然后,利用PyTorch提供的工具和函数,构建一个神经网络模型。可以选择使用卷积神经网络(CNN)或循环神经网络(RNN)等结构。 训练过程中,需要先将数据集划分为训练集和测试集。通过将训练集输入到神经网络中,进行反向传播和优化,使网络能够逐渐学习到正确的算式识别方式。在每次迭代中,可以使用损失函数来评估模型的性能,并根据损失函数的结果调整模型的参数。 完成网络训练后,可以使用测试集来验证模型在未知数据上的表现。将测试集输入到训练好的模型中,通过模型的输出来进行算式识别。 通过PyTorch提供的函数和工具,我们可以实现对算式的自动识别和解析。这样就可以将输入的算式转换为计算机能够理解和处理的形式,从而实现更便捷和高效的数学计算和问题求解。 总而言之,PyTorch 可以用于算式识别,通过训练神经网络模型来实现对输入算式的自动识别和解析。这样可以方便地将算式转换为计算机可理解的形式,为数学计算和问题求解提供支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值