求一个整数任意次方的最后三位数.用C++来编的,有谁能帮帮我?
7个回答
2005-12-21 · 知道合伙人数码行家
关注
展开全部
只要将求出的大于1000的数只取百十个位就好了,然后再进行计算,每次都如此,就不会出现溢出,因为千位以上对最后三位没影响,程序如下
int lastthr(int num,int n) //num的n次方
{
int thr,tmp;
tmp=num%1000; //对1000取余,得最后三位
thr=tmp;
while(--n)
{
thr*=tmp;
thr%=1000;
}
return thr;
}
对于num,n均为正情况,以上程序在Dev-C++通过。
int lastthr(int num,int n) //num的n次方
{
int thr,tmp;
tmp=num%1000; //对1000取余,得最后三位
thr=tmp;
while(--n)
{
thr*=tmp;
thr%=1000;
}
return thr;
}
对于num,n均为正情况,以上程序在Dev-C++通过。
展开全部
#include<iostream>
using namespace std;
void main()
{
const int N=10; //N次方
int i=0;
int num=25; //整数num
int sum=1;
for(i=0;i<N;i++)
{
sum*=num;
}
printf("%d\n",sum%1000); //输出最后三位数
}
using namespace std;
void main()
{
const int N=10; //N次方
int i=0;
int num=25; //整数num
int sum=1;
for(i=0;i<N;i++)
{
sum*=num;
}
printf("%d\n",sum%1000); //输出最后三位数
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
long abc(long x ,long y )
{
long u =0;
if(y>=3)
u=x%10
else
u=x%1000;
for(long i=0;i<y;i++)
u*=x;
return u%1000;
}
{
long u =0;
if(y>=3)
u=x%10
else
u=x%1000;
for(long i=0;i<y;i++)
u*=x;
return u%1000;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<iostream>
using
namespace
std;
void
main()
{
const
int
N=10;
//N次方
int
i=0;
int
num=25;
//整数num
int
sum=1;
for(i=0;i<N;i++)
{
sum*=num;
}
printf("%d\n",sum%1000);
//输出最后三位数
}
using
namespace
std;
void
main()
{
const
int
N=10;
//N次方
int
i=0;
int
num=25;
//整数num
int
sum=1;
for(i=0;i<N;i++)
{
sum*=num;
}
printf("%d\n",sum%1000);
//输出最后三位数
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
int a(int b ,int c )
{
int d = b;
while( --c > 0 )
{
d *= b;
d &= 0xfff;
}
return d;
}
{
int d = b;
while( --c > 0 )
{
d *= b;
d &= 0xfff;
}
return d;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询