亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 30414 | 回復(fù): 97
打印 上一主題 下一主題

[算法] 變態(tài)的算法題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2011-04-27 21:00 |只看該作者 |倒序瀏覽
一個N位的十進(jìn)制正整數(shù),如果它的每個位上的數(shù)字的N次方的和等于這個數(shù)本身,則稱其為花朵數(shù)。
例如:
當(dāng)N=3時,153就滿足條件,因為 1^3 + 5^3 + 3^3 = 153,這樣的數(shù)字也被稱為水仙花數(shù)(其中,“^”表示乘方,5^3表示5的3次方,也就是立方)。
當(dāng)N=4時,1634滿足條件,因為 1^4 + 6^4 + 3^4 + 4^4 = 1634。
當(dāng)N=5時,92727滿足條件。
實際上,對N的每個取值,可能有多個數(shù)字滿足條件。

程序的任務(wù)是:求N=21時,所有滿足條件的花朵數(shù)。注意:這個整數(shù)有21位,它的各個位數(shù)字的21次方之和正好等于這個數(shù)本身。
如果滿足條件的數(shù)字不只有一個,請從小到大輸出所有符合條件的數(shù)字,每個數(shù)字占一行。因為這個數(shù)字很大,請注意解法時間上的可行性。要求程序在3分鐘內(nèi)運行完畢。

論壇徽章:
0
2 [報告]
發(fā)表于 2011-04-27 22:21 |只看該作者
# include <stdio.h>
# include <math.h>

int IsYes(int goal, int len)
{
        int i = 0, sum = 0, goal1=goal;
        int * pArr;

        pArr = (int)malloc(sizeof(int) * len);
        while(goal > 10)
        {
                pArr[i] = goal % 10;
                i++;
                goal /= 10;
        }
        pArr[i] = goal;

        for(i=0; i<len; i++)
        {
                sum += pow(pArr[i], len);
        }
        if(sum == goal1)return 1;
        else return 0;
}

int main(void)
{
        int len = 3, i = 0;
        int LBound = 0, UBound = 0;

        scanf("%d", &len);
        LBound = pow(10, len-1);
        UBound = pow(10, len);

        for(i=LBound; i<UBound; i++)
        {
                if( IsYes(i, len) )printf("%d\n", i);
        }

        return 0;
}

論壇徽章:
0
3 [報告]
發(fā)表于 2011-04-27 22:28 |只看該作者
我錯了  沒看到后面的 程序的任務(wù)是:求N=21時

論壇徽章:
2
白羊座
日期:2013-11-18 19:52:42辰龍
日期:2014-09-07 07:46:06
4 [報告]
發(fā)表于 2011-04-28 08:27 |只看該作者
大數(shù)乘法和加法問題

論壇徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52雙子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午馬
日期:2013-10-18 21:43:38
5 [報告]
發(fā)表于 2011-04-28 08:44 |只看該作者
這個肯定不能死算吧

論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設(shè)計版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀(jì)念徽章
日期:2015-12-22 16:50:40IT運維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術(shù)圖書徽章
日期:2016-07-19 13:54:03程序設(shè)計版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
6 [報告]
發(fā)表于 2011-04-28 09:25 |只看該作者
感覺主要是時間問題吧

論壇徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:50:28
7 [報告]
發(fā)表于 2011-04-28 10:11 |只看該作者
要先完成一個大數(shù)運算庫。

論壇徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-08-03 06:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-08-04 06:20:00
8 [報告]
發(fā)表于 2011-04-28 14:40 |只看該作者
我的想法是湊數(shù),8^21已經(jīng)很小,
7^21已經(jīng)很小,對于9^21大小都可以忽略.
9肯定是主流
但不能超過9個
于是可以從開始湊
1,2,3,4,5,6,7,8,9個9開始湊

論壇徽章:
0
9 [報告]
發(fā)表于 2011-04-28 14:49 |只看該作者
可以把N=3那肯定是0-3之間,得到的結(jié)果,在是N=5之間,在是N=7之間,這個題可以用數(shù)學(xué)的的思維去想。

論壇徽章:
1
天秤座
日期:2014-04-27 07:42:20
10 [報告]
發(fā)表于 2011-04-28 17:40 |只看該作者
本帖最后由 A.com 于 2011-04-28 17:52 編輯

其實就是0、1、2097152……9^21的組合,要求組合的和是個21位的數(shù)字且順序符合。
先湊夠數(shù)字,就是21個數(shù)之和大于10^20。然后是檢測21個元素的集合和這個和的數(shù)字集合是否一致
程序需要循環(huán)21^21次。。。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP