Acwing.504 转圈游戏(带取余的快速幂)

题目

n个小伙伴(编号从 0到 n−1)围坐一圈玩游戏。

按照顺时针方向给 n个位置编号,从 0到 n−1。

最初,第 0号小伙伴在第 0号位置,第 1号小伙伴在第 1号位置,...,依此类推。

游戏规则如下:每一轮第 0号位置上的小伙伴顺时针走到第 m号位置,第 1号位置小伙伴走到第 m+1号位置,...,依此类推,第 n−m号位置上的小伙伴走到第 0号位置,第 n−m+1号位置上的小伙伴走到第 1号位置,...,第 n−1号位置上的小伙伴顺时针走到第 m−1号位置。

现在,一共进行了 10k轮,请问 x号小伙伴最后走到了第几号位置。

输入格式

输入共 1行,包含 4个整数 n、m、k、x,每两个整数之间用一个空格隔开。

输出格式

输出共 1行,包含 1个整数,表示 10k轮后 x号小伙伴所在的位置编号。

数据范围

1<n<106

0<m<n

1≤x≤n

0<k<109

输入样例:

java 复制代码
10 3 4 5

输出样例:

java 复制代码
5

题解

java 复制代码
import java.util.Scanner;

/**
 * @author akuya
 * @create 2024-04-05-11:11
 */
public class CircleGame {
    static int n,m,k,x;
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
         n=scanner.nextInt();
         m=scanner.nextInt();
         k=scanner.nextInt();
         x=scanner.nextInt();

         long num=quick(10,k);
         num=(x+(num*m))%n;

        System.out.println(num%n);


    }

    public static long quick(long a,int s){
        long ans=1;
        while(s!=0) {
            if ((s & 1) != 0) {
                ans = (ans * a) % n;
            }
            a = (a*a)%n;
            s >>= 1;
        }

        return ans;
    }
}

思路

这道题没有任何思路可言,相信大家都能看出这只是一道数据较大的小学数学题,那么,我们需要懂的就只有如何使用快速幂,并且在快速幂中进行取余。大家看代码模板即可。

相关推荐
云栖梦泽在18 小时前
AI安全入门:AI模型泄露的风险与防护措施
人工智能·算法·动态规划
水木流年追梦18 小时前
大模型入门-应用篇3-Agent智能体
开发语言·python·算法·leetcode·正则表达式
洛水水18 小时前
【力扣100题】31.二叉树的层序遍历
算法·leetcode·职场和发展
君义_noip18 小时前
CSP-S 2025 入门级 第一轮(初赛) 完善程序(1)
c++·算法·信息学奥赛·初赛·csp 第一轮
洛水水18 小时前
【力扣100题】41.爬楼梯
算法·leetcode·职场和发展
sheeta199820 小时前
LeetCode 每日一题笔记 日期:2026.05.13 题目:1674. 使数组互补的最少操作次数
笔记·算法·leetcode
liulilittle20 小时前
TCP UCP v1.0:BBR 的非破坏性约束层
网络·c++·网络协议·tcp/ip·算法·c·通信
每天回答3个问题20 小时前
LeetCodeHot100|回溯算法、46.全排列、78.子集、17.电话号码的字母组合
算法·深度优先·回溯
Liangwei Lin21 小时前
LeetCode 287. 寻找重复数
算法·leetcode·职场和发展
OCR_133716212751 天前
护照OCR校验位技术解析:从算法逻辑到工程落地,筑牢证件核验安全线
人工智能·算法