日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

第二届战神杯线上编程挑战赛月赛第一题:回文数

發布時間:2025/3/20 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 第二届战神杯线上编程挑战赛月赛第一题:回文数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目詳情:


Njzy學習了回文串后聯想到了回文數,他希望統計出一個區間內的全部回文數。如今給定一個閉區間[a,b],求這個區間里有多少個回文數。

比方[20,30],僅僅有一個回文數那就是22.

?


輸入描寫敘述:

? ?輸入包括多組測試數據,每組測試數據包括兩個整數a,b,

(0<a<=b<10^6)。

輸出描寫敘述:

? ?對于每組測試數據輸出對應的答案。

?



答題說明:


輸入例子:

1

10

20

30

300

400

輸出例子:

9

1

10


解題思路:

total[i]代表從1到i之間有多少回文數,預處理一下,要求a和b之間有多少回文數,直接輸出 total[b]-total[a-1] 就能夠了。這題第一次提交的時候悲劇了,原因是數組越界

const int maxn=1000000+10; ? int total[maxn] ,后來預處理total數組的時候,從1一直循環到了maxn,越界了,數組下標最大是 maxn-1,哎,悲劇。

題外話:這個月非常少寫博文,正忙著期末考試復習,一定得把成績提上去。


代碼:

#include <iostream> #include <string.h> using namespace std; const int maxn=1000000; int num[10]; int total[maxn+10];//total[i]代表從1到i之間有多少回文數bool pd(int n)//推斷是否是回文數 {int k=0;int temp=n;while(temp){num[++k]=temp%10;temp/=10;}for(int i=1;i<=k/2;i++){if(num[i]!=num[k-i+1])return false;}return true; }void cal(int n)//預處理total[i] {int k=0;for(int i=1;i<=n;i++){if(pd(i))k++;total[i]=k;} }int main() {total[0]=0;cal(maxn);int a,b;while(cin>>a>>b){cout<<total[b]-total[a-1]<<endl;}return 0; }
后來在網上看到別人推斷是否是回文數的函數比我的要好:

例如以下:

bool pd(int n)//推斷是否是回文數 {int temp=n;int m=0;while(temp){m=m*10+temp%10;//m為n的逆序temp/=10;}return n==m; }

總結

以上是生活随笔為你收集整理的第二届战神杯线上编程挑战赛月赛第一题:回文数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。