双模幂运算Java

news2025/1/15 13:15:08

题目:

给你一个下标从 0 开始的二维数组 variables ,其中 variables[i] = [ai, bi, ci, mi],以及一个整数 target 。
如果满足以下公式,则下标 i 是 好下标:
- 0 <= i < variables.length
-

返回一个由 好下标 组成的数组,顺序不限 。

解题

  1. 初始化:创建一个空的 ArrayList 来存储满足条件的索引。
  2. 遍历数组:使用一个 for 循环遍历 variables 数组。
  3. 提取元素:在每次循环中,从当前的 variables[i] 中提取 a、b、c 和 m。
  4. 计算 val1:计算 abmod  10abmod10 的值。这里使用一个内嵌的 for 循环来连续乘以 a,每次乘法后都取模 10,以保持结果在个位数。
  5. 模运算:将 val1 模 m,得到最终的 val1 值。
  6. 计算 val2:使用另一个内嵌的 for 循环计算 (val1)cmod  m(val1)cmodm 的值。
  7. 条件判断:检查 val2 是否等于给定的 target。
  8. 添加索引:如果条件成立,将当前索引 i 添加到结果列表中。
  9. 返回结果:循环结束后,返回包含所有满足条件索引的列表。

代码

class Solution {
    public List<Integer> getGoodIndices(int[][] variables, int target) {
        List<Integer> ans = new ArrayList<>();
        int n = variables.length;
        
        for (int i = 0; i < n; i++) {
            int a = variables[i][0] % 10; 
            int b = variables[i][1];
            int c = variables[i][2];
            int m = variables[i][3];
            
            // 使用快速幂算法计算val1
            long val1 = fastPowerMod(a, b, 10);
            val1 %= m;
            
            // 再次使用快速幂算法计算val2
            long val2 = fastPowerMod((int)val1, c, m);
            
            if (val2 == target) {
                ans.add(i);
            }
        }
        return ans;
    }
    // 快速幂算法,计算base^exp % mod
    private long fastPowerMod(int base, int exp, int mod) {
        long result = 1;
        base %= mod; // 保证base在模m范围内
        while (exp > 0) {
            if ((exp & 1) != 0) {
                result = (result * base) % mod;
            }
            base = (base * base) % mod;
            exp >>= 1;
        }
        return result;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1968355.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RK3568平台(触摸篇)双屏异触调试

一.现象 现象&#xff1a;准备两块主屏都接触摸框&#xff0c;A屏的HDMIOUT外接B屏的HDMIIN&#xff0c;用手触摸A屏&#xff0c;发现A屏没有触摸&#xff0c;A屏幕的触摸现象在B屏那边。 现要求&#xff1a;用手触摸A屏&#xff0c;A屏要有现象&#xff0c;不能现象在B屏那边…

《Transformer Scale Gate for Semantic Segmentation》CVPR2023

摘要 论文提出了一种名为Transformer Scale Gate&#xff08;TSG&#xff09;的模块&#xff0c;用于优化在语义分割任务中多尺度上下文信息的编码。现有的基于Transformer的分割模型在组合不同尺度的特征时没有进行选择&#xff0c;这可能导致次优尺度的特征降低分割的准确性…

【网络】UDP协议——传输层、端口号、UDP协议、UDP协议端格式、UDP的特点、UDP的缓冲区、UDP使用注意事项

文章目录 Linux网络1. 传输层1.1 端口号1.2 UDP协议1.2.1 UDP协议端格式1.2.2 UDP的特点1.2.3 UDP的缓冲区1.2.3 UDP使用注意事项1.2.5 基于UDP的应用层协议 Linux网络 1. 传输层 传输层&#xff1a;是 OSI 模型和 TCP/IP 模型中的重要层次&#xff0c;位于网络层之上、应用层…

推荐一个gpt镜像网站

包含现在主流的大语言模型 一个网站&#xff0c;各种模型随意切换和体验 集成多种功能 不止于对话&#xff0c;更有文生图&#xff0c;思维导图等多种功能 支持多个平台 除了网页版&#xff0c;更有安卓, mac os, ipad os等多个平台&#xff0c;随时随地方便同步和使用 …

【大模型】【智能体】agent导论

基本的图像 react&#xff1a; prompt&#xff1a;

营收保持增长,汽车之家掌握了什么“流量密码”?

从汽车之家新鲜出炉的“成绩单”来看&#xff0c;汽车行业的流量生意依然红火。 财报显示&#xff0c;2024年第二季度&#xff0c;汽车之家实现总营收18.7亿元&#xff0c;同比增长2.2%&#xff1b;经调整净利润5.72亿元&#xff0c;经调整净利润率达30.6%。其中&#xff0c;在…

MySQL:管理和操作数据表

数据表是数据库的重要组成部分&#xff0c;每一个数据库都是由若干个数据表组成的。没有数据表就无法在数据库中存放数据。MySQL数据表的管理和操作是数据库管理员和开发人员日常工作中不可或缺的一部分。 创建数据表 CREATE 创建数据表的过程是规定数据列的属性的过程&#…

数字图像处理 --- 图像的离散余弦变换(python实战)

图像的离散余弦变换(python实战) 这篇文章是我上两篇文章的延续&#xff0c;主要是觉得前面的文章太长了&#xff0c;所以把关于图像的DCT变换部分单独拎出来放到这里&#xff0c;这两篇文章分别是&#xff1a; 1&#xff0c;一维DCT 数字信号处理 --- 一维离散余弦变换(pyth…

搜维尔科技:【研究】Haption的自动识别技术

Real-Time Interaction for Delmia Human RTID Human “Real-Time Interaction for Delmia Human” 是个附加在Delmia V5™上的软件&#xff0c;它能让使用者使用数字人体模型在虚拟环境中进行实时互动仿真 在Delmia 中使用RTI &#xff0c;使用者可以模拟进行以下研究: 1. 可…

table car vs. table cars:数据库命名用单数还是复数?

数据库的命名方式已经形成了许多共识&#xff0c;比如全部小写、下划线分隔、使用标准缩写等&#xff1b;其中就包括「使用单数名词」。 用户 jonr 在 reddit 网的程序员笑话&#xff08;ProgrammerHumor&#xff09;社区发了一篇帖子&#xff0c;调侃这些数据库命名方式的共识…

突破csdn每日15篇文章限制的方法

买一个vip年会员248元&#xff0c;就可以了.......

Linux-3:Shell编程——基础语法(0-50%)

目录 前言 一、变量 1.定义变量 2.使用变量 3.修改变量 4.将命令的结果赋值给变量 5.只读变量 6.删除变量 二、传递参数 三、字符串 1.字符串举例 2.统计字符串长度 3.字符串拼接 4.截取字符串 总结 前言 Shell是一种程序设计语言。作为命令语言&#xff0c;它…

算法学习day26

滑动窗口系列题 一、替换后的最长重复子串 给你一个字符串 s 和一个整数 k 。你可以选择字符串中的任一字符&#xff0c;并将其更改为任何其他大写英文字符。该操作最多可执行 k 次。 在执行上述操作后&#xff0c;返回 包含相同字母的最长子字符串的长度。 输入&#xff1a…

MySQL--MySQL函数

前言&#xff1a;本博客仅作记录学习使用&#xff0c;部分图片出自网络&#xff0c;如有侵犯您的权益&#xff0c;请联系删除 MySQL函数 一、MySQL函数简介 函数表示对输入参数值返回一个具有特定关系的值&#xff0c;MSOL提供了大量丰富的函数&#xff0c;在进行数据库管理以…

CTFHub——XSS全系列

1、反射型&#xff1a; 发现为表单式&#xff0c;猜测哪个可能存在注入漏洞&#xff0c;分别做测试注入发现name框存在xss漏洞 输入发现有回显但不是对方cookie&#xff0c;参考wp发现要用xss线上平台 将xss平台测试语句注入&#xff0c;将得到的url编码地址填入url框&#xf…

Mongodb集合操作

文章目录 1、进入容器2、如果数据库不存在&#xff0c;则创建数据库&#xff0c;否则切换到指定数据库3、在 MongoDB 中&#xff0c;创建集合不是必须操作。当你插入一些文档时&#xff0c;MongoDB 会自动创建集合。4、查看数据库列表5、查看集合6、显示创建集合7、删除集合 1、…

Raspberry Pi Docker 运行 IRIS

在 Raspberry Pi 上成功安装 Docker 后可以安装 IRIS 数据库。 安装的命令为&#xff1a; docker run --name my-iris -d --publish 1972:1972 --publish 52773:52773 intersystems/irishealth-community:latest-em-linux-arm64v8 注意&#xff0c;我们这里暴露了 2 个端口&a…

Spring框架 配置Gateway网关/spring cloud gateway 基础入门案例教程

文章目录 目录 文章目录 安装流程 小结 概要安装流程技术细节小结 概要 网关作为微服务集群唯一的对外入口,可以实现很多功能. 例如: 统一的解决跨域(一个ajax请求 origin域名和请求目标url中域名不同,ip不同,域名不同,端口不同,都会引发的问题)问题. 统一的身份认证.认证解…

OpenStack Yoga版安装笔记(十)placement练习

1、练习场景说明 在OpenStack Yoga版安装笔记&#xff08;九&#xff09;中&#xff0c;placement已经在controller node虚拟机上安装完成&#xff0c;并且已经成功拍摄了快照。 此时&#xff0c;controller node虚机已经安装了keystone、keystone DB、glance、glance DB、Open…

反序列化漏洞vulhub靶场serial

环境搭建 下载 https://download.vulnhub.com/serial/serial.zip 解压出来就是这种 你会得到一个这样的文件&#xff0c;这里使用VMware新建一个虚拟机&#xff0c;这里记录比较重要的几部分。 这里就是使用我们刚才下过来的。 漏洞过程详解 1.信息收集 打开靶机&#xff0…