国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

雙基回文數(shù)

2019-11-09 19:54:06
字體:
供稿:網(wǎng)友

記錄下寫的代碼和題目方便自己不會忘記(進(jìn)制函數(shù)含借鑒) 問題描述:如果一個正整數(shù)n至少在兩個不同的進(jìn)位制b1和b2下都是回文數(shù)(2<=b1,b2<=10),則稱n是雙基回文數(shù)(注意:回文數(shù)不能包含前導(dǎo)0)。 輸入正整數(shù)S<10^6,輸出比S大的最小雙基回文數(shù)。

樣例輸入:1600000

樣例輸出:1632995

分析:最自然的想法就是:從S+1開始,依次判斷每個數(shù)是否為雙基回文數(shù),而在判斷時要列舉所有可能的基數(shù)(2~10),一切都是那么的”暴力“。然而令人意外的是,這樣做對于S<10^6這樣的小規(guī)模數(shù)據(jù)來說是足夠快的。因為這種數(shù)密度很大,這也是為什么不會爆的原因。

include<iostream>#include<string.h>using namespace std;int fun(int x,int n){ int a[100]; int k=0; memset(a,0,sizeof(a)); for(int i=0;;i++){ a[i]=x%n; x/=n; if(x==0){ k=i; break; } } int flag=1; for(int i=0;i<=k/2;i++){ if(a[i]!=a[k-i]){ flag=0; break; } } if(flag==1)return 1; else return 0;}int main(void){ int n; while(cin>>n){ for(;;n++){ int k=0; int flag=0; for(int i=2;i<=10;i++){ if(fun(n,i)) k++; if(k>=2){ flag=1; break; } }if(flag){ cout<<n<<endl; break; } } }}
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 永登县| 肃南| 公主岭市| 福清市| 沅江市| 扬州市| 浦东新区| 岗巴县| 北安市| 五台县| 南昌市| 余干县| 高密市| 土默特左旗| 乐陵市| 拜泉县| 浦东新区| 朝阳市| 玉屏| 江安县| 大理市| 桃江县| 维西| 阿鲁科尔沁旗| 齐河县| 隆安县| 望都县| 射阳县| 灵山县| 汕尾市| 永德县| 台中县| 武邑县| 政和县| 牙克石市| 通化县| 大悟县| 三河市| 长乐市| 岑溪市| 屏南县|