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

首頁 > 學院 > 開發設計 > 正文

PAT-B 1016. 部分A+B (15)

2019-11-11 01:42:42
字體:
來源:轉載
供稿:網友

題目鏈接在此。

這個題目在做的過程中發現需要注意的點有:

scanf的輸入控制符(%lld,%d),可參見這篇文章。若一個數由n個x組成,求這個數

以上也是解這道題目的關鍵所在。

剛開始的思路是想: 將輸入的A,B讀入char[]數組中,然后用循環判斷每一位是否等于DA,DB,得到等于DA,DB的個數,然后得出PA,PB,最后求得結果。這種方法也不算復雜。

后來想到,既然又是整數的處理,是否能用除法和取余這兩種運算呢?后來想通了,《算法筆記》上的解法也是如此,代碼如下:

#include<stdio.h>int main(){ long long A,B; int DA,DB; int PA = 0,PB = 0; int JA,JB; int sa = 0, sb = 0; scanf("%lld %d %lld %d",&A,&DA,&B,&DB); //拿到A中DA的個數 while( A != 0 ){ JA = A % 10; if( JA == DA ){ sa ++; } A /= 10; } //拿到B中DB的個數 while( B != 0 ){ JB = B % 10; if(JB == DB){ sb++; } B /= 10; } //求PA if(sa){ PA = DA; for(int i = 1; i < sa; i++){ PA = PA*10 + DA; } } //求PB if(sb){ PB = DB; for(int i = 1; i < sb; i++){ PB = PB*10 + DB; } } 其實代碼可以簡化成如下:

#include<stdio.h>int main(){ long long A,B; int DA,DB; int PA = 0,PB = 0; int JA,JB; int sa = 0, sb = 0; scanf("%lld %d %lld %d",&A,&DA,&B,&DB); //拿到A中DA的個數 while( A != 0 ){ JA = A % 10; if( JA == DA ){ PA = PA*10 + DA; } A /= 10; } //拿到B中DB的個數 while( B != 0 ){ JB = B % 10; if(JB == DB){ PB = PB*10 + DB; } B /= 10; } printf("%d/n",PA+PB); return 0;}

最后,還是提醒自己注意scanf的輸入格式控制!!!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 察雅县| 连州市| 延寿县| 仁布县| 乐清市| 淳化县| 额济纳旗| 宿州市| 灵川县| 岑溪市| 永新县| 保山市| 福泉市| 榆中县| 龙南县| 邮箱| 哈密市| 重庆市| 和田市| 法库县| 进贤县| 伊吾县| 体育| 九台市| 日照市| 德钦县| 麦盖提县| 达拉特旗| 梅州市| 昭苏县| 文山县| 宁夏| 青州市| 江西省| 阿城市| 玛曲县| 南充市| 会昌县| 雅江县| 淮南市| 彭阳县|