写了半天的思路和文字,找不到了。这次就不写思路了,直接贴代码。分析问题时要注意内存溢出、运算效率。顺便说一句。网易POJ平台今天的表现太差了。
另外看了下Accept的结果, GCC的运行效率高于java 40 倍左右,也明显高于G++ 。
描述
计算a的b次方对9907取模的值。
输入
第一行有一个正整数T,表示有T组测试数据。
接下来T行,每行是一组测试数据,包含两个整数a和b。
其中T<=10000, 0 <=a,b < 2^31。
输出
有T行,依次输出每组数据的结果。
样例输入
3
1 2
2 3
3 4
样例输出
1
8
81
简略分析:
m= a % c
x = a^b % c = m^b %c
当b = 2n 则: x = ( m^n % c ) ^ 2 % c
当b = 2n+1 则: x = ((( m^n % c ) ^ 2 % c) * m )% c
我的代码:
package poj.youdao.b;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader input = new BufferedReader(new InputStreamReader(System.in));
int line = new Integer(input.readLine().trim());
for(int i=0;i<line;i++){
String[] text = input.readLine().split("\\s");
int a = new Integer(text[0]);
int b = new Integer(text[1]);
System.out.println(getMod(a,b,9907));
}
input.close();
}
public static int getMod(int a, int b, int c) {
int halfB = b / 2;
int mod=0;
if(b<=1){
mod = a % c;
}
else{
mod = getMod(a, halfB, c);
if (b % 2 == 1) {
mod = (((mod * mod)%c) * (a%c) ) % c;
} else {
mod = (mod * mod ) % c;
}
}
return mod;
}
}
分享到:
相关推荐
标题中的"perl-5.24-win64.rar"指的是Perl编程语言的Windows 64位版本的压缩包,版本号为5.24。Perl是一种高级的、通用的、解释型、动态的编程语言,尤其适合处理文本操作和系统管理任务。在Windows环境下,Perl的...
**计算机常用工具软件--教案5.24(1--2节)** 本教案主要围绕第9章的内容展开,讲解了如何使用下载与上传文件的工具软件,特别关注了Flash Get快车这一流行的下载管理工具。Flash Get是一款高效、便捷的多线程下载...
ActivePerl-5.24.0.2400-MSWin32-x64-300558
ROS-5.24-L6是ROS的一个特定版本,可能是为了满足特定硬件或项目需求而发布的。 在描述中提到的“ROS-5.24-L6授权”,意味着这个版本可能包含特定的授权条款,可能涉及到使用、修改或分发该软件的法律限制。用户在...
图数据库neo4j-community-5.24.2-unix.tar版本,适用于国内无法访问neo4j官网的linux版本下载。
标题中的"ActivePerl-5.24.1.2402-MSWin32-x64-401627"指的是这个版本的ActivePerl是专为64位(x64)的Windows操作系统设计的。它是由ActiveState公司开发的,该公司致力于提供跨平台的Perl解决方案。 Perl是一种...
标题中的"ActivePerl-5.24.3.2404-x86_64-linux-glibc-2.15-404865.tar.gz"表明这是一个基于Perl编程语言的软件发行版,具体来说是ActivePerl的一个版本。ActivePerl是由ActiveState公司维护的Perl解释器,它为...
图数据库neo4j-community-5.24.2-windows版本,适用于国内无法访问neo4j官网的同学。
在给定的“Keil v5.24 rar压缩包”中,用户可以获取到这个版本的Keil工具链。 Keil v5.24作为重要的更新版本,可能包含了以下关键知识点: 1. **C/C++编译器**:Keil提供了一个强大的C/C++编译器,能够生成高效的...
"MSWin32-x64"表明这是专为64位Windows操作系统设计的版本,而"5.24.2.2403"则代表该版本基于Perl的5.24.2核心,版本号2403意味着它是ActivePerl的特定构建版本。这个压缩包包含了ActivePerl的安装程序,文件名为...
标题“ActivePerl_x64_5.24”指的是ActivePerl的一个特定64位版本,其核心是Perl编程语言的5.24版。ActivePerl是Perl的一种预编译版本,为Windows、Mac OS X和各种Unix/Linux系统提供了一个方便的安装包,使开发者...
ActivePerl-5.24.1.2402-MSWin32-x64-
**PyPI官网下载:codeforlife_portal-5.24.2-py2.py3-none-any.whl** PyPI(Python Package Index)是Python社区官方的软件包仓库,它为Python开发者提供了一个集中发布和获取Python软件包的平台。在本例中,我们...
2021人教版数学一年级上册课件-5.24 练习十六.pptx
KEIL调试J-link驱动安装包是一个为了解决KEIL集成开发环境在连接J-Link调试器时可能出现的问题而准备的资源集合。这个压缩包包含了不同版本的J-Link驱动程序,旨在帮助用户找到与他们的系统和KEIL软件兼容的最佳版本...
这个压缩包文件"ActivePerl-5.24.1.2402-MSWin32-x64-401627.exe.zip"包含了64位版本的ActivePerl,适用于Windows操作系统。Perl是一种强大的文本处理语言,常用于系统管理、网络编程、CGI脚本、数据分析等领域。 ...
Keil MDK is the most comprehensive software development solution for ARM-based microcontrollers and includes all components ...MDK Version 5.24 is focusing on improvements for users of ARM Compiler 6.