求2011的N次方,提交后显示运行时间超时,求解答

云斜月 2013-04-07 10:51:14
#include<iostream>
#include<vector>
using namespace std;
int cal(unsigned int val )
{
unsigned int n=1;
int m=2011;
while(n++<val)
{
m*=2011;
m=m%10000;

}
return m;
}
int main()
{
int n;
cin>>n;
vector<int>vec;
int m;
for(int i=1;i<=n;++i)
{
cin>>m;
vec.push_back(m);

}
for(int i=0;i!=vec.size();++i)
cout<<cal(vec[i])<<endl;
return 0;
}
求2011的N次方的后四位,时间限制1000ms 运行时间超时,求解,
...全文
282 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
zilaishuichina 2013-04-07
  • 打赏
  • 举报
回复


2011的1次方到200次方的后4位 lz发现规律了么?

现在lz可以直接查表了
nice_cxf 2013-04-07
  • 打赏
  • 举报
回复
这种题目不是这样算的,要找出规律 实际上最多1000次必然有规律,先找规律然后求模就可以了
云斜月 2013-04-07
  • 打赏
  • 举报
回复
引用 2 楼 zilaishuichina 的回复:
2011的1次方到200次方的后4位 lz发现规律了么? 现在lz可以直接查表了
每500个重复一次,,,
云斜月 2013-04-07
  • 打赏
  • 举报
回复
#include<iostream>
#include<vector>
using namespace std;
int cal(unsigned int val )
{
unsigned int n=1;
int m=2011;
while(n++<val)
{
m*=2011;
m=m%10000;

}
return m;
}
inline int four(const int num)
{

return num%500;
}
int main()
{

int array[501];
for(int i=1;i!=501;++i)
{
array[i]=cal(i);
}

int n;
cin>>n;
vector<int>vec;
int m;
for(int i=1;i<=n;++i)
{
cin>>m;
vec.push_back(m);

}
for(int i=0;i!=vec.size();++i)
cout<<array[four(vec[i])]<<endl;

return 0;
}

64,646

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧