标题:尾数相等问题
只看楼主
丽娜13
Rank: 2
来 自:湖南
等 级:论坛游民
帖 子:21
专家分:18
注 册:2014-6-20
结帖率:75%
已结贴  问题点数:20 回复次数:9 
尾数相等问题
一个自然数K(2≤K),若存在自然数M和N(M大于N),使得K^M和K^N均大于或等于1000,且它们的末尾三位数相等,则称M和N是一对“K尾相等数”。
输入包含若干个测试用例,每个测试用例占一行,为一个自然数K
用一行输出符合要求的最小M+N值
求大神给点较优算法,c++
搜索更多相关主题的帖子: 自然数 
2014-06-21 13:27
外部三电铃
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:那一年
等 级:贵宾
威 望:55
帖 子:2004
专家分:7306
注 册:2007-12-17
得分:7 
先爆照,不爆照不给你做作业

那一年,苍井空还是处女
2014-06-21 13:29
丽娜13
Rank: 2
来 自:湖南
等 级:论坛游民
帖 子:21
专家分:18
注 册:2014-6-20
得分:0 
回复 2 楼 外部三电铃
肿么阔以这样。。。妹子会害羞的

我是一只小菜鸟呀小菜鸟,怎么飞也飞也飞不高T-T
2014-06-21 13:30
丽娜13
Rank: 2
来 自:湖南
等 级:论坛游民
帖 子:21
专家分:18
注 册:2014-6-20
得分:0 
求回复,求解答。。。。。

我是一只小菜鸟呀小菜鸟,怎么飞也飞也飞不高T-T
2014-06-21 13:37
wp231957
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:神界
等 级:版主
威 望:422
帖 子:13681
专家分:53296
注 册:2012-10-18
得分:7 
指数级别的涉及到大数运算了

DO IT YOURSELF !
2014-06-22 06:10
Susake
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:女儿国的隔壁
等 级:贵宾
威 望:23
帖 子:2288
专家分:6481
注 册:2012-12-14
得分:7 
...

仰望星空...........不忘初心!
2014-06-22 07:02
Susake
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:女儿国的隔壁
等 级:贵宾
威 望:23
帖 子:2288
专家分:6481
注 册:2012-12-14
得分:0 
先百度一下    快速幂,弄懂后,可以秒杀了~~

仰望星空...........不忘初心!
2014-06-22 07:05
丽娜13
Rank: 2
来 自:湖南
等 级:论坛游民
帖 子:21
专家分:18
注 册:2014-6-20
得分:0 
回复 5 楼 wp231957
这样纸啊。。。。

我是一只小菜鸟呀小菜鸟,怎么飞也飞也飞不高T-T
2014-06-22 11:08
丽娜13
Rank: 2
来 自:湖南
等 级:论坛游民
帖 子:21
专家分:18
注 册:2014-6-20
得分:0 
回复 7 楼 Susake
谢谢帅锅锅

我是一只小菜鸟呀小菜鸟,怎么飞也飞也飞不高T-T
2014-06-22 11:12
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
程序代码:
#include <stdio.h>

unsigned foo( unsigned k )
{
    unsigned mark[1000] = { 0 };
    unsigned i = 1;
    unsigned v = k;
    for( ; v<1000; ++i, v*=k );
    k %= 1000;
    v %= 1000;
    for( ; mark[v]==0; ++i, v=(v*k)%1000 )
        mark[v] = i;
    return mark[v] + i;
}

#include <assert.h>

int main()
{
    assert( foo(2) == 120 );
    assert( foo(25) == 7 );
    assert( foo(125) == 6 );
    assert( foo(1000) == 3 );
    assert( foo(1234) == 56 );
    assert( foo(111111) == 52 );
    assert( foo(1000003) == 102 );
    assert( foo(123454321) == 27 );

    return 0;
}
2014-06-23 10:38



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-433211-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.666795 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved