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

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

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

2019-11-10 23:05:09
字體:
來源:轉載
供稿:網友

題目鏈接在此。

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

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的輸入格式控制?。?!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东台市| 泸定县| 阿鲁科尔沁旗| 永川市| 宝兴县| 嘉善县| 靖边县| 冕宁县| 和龙市| 庆元县| 正蓝旗| 蒙山县| 社会| 萝北县| 灵石县| 镇原县| 万荣县| 枝江市| 乌拉特前旗| 临朐县| 罗甸县| 河曲县| 鄂尔多斯市| 开平市| 芮城县| 房山区| 廊坊市| 石屏县| 都安| 册亨县| 麻城市| 大石桥市| 城口县| 论坛| 双江| 古丈县| 乐山市| 陆丰市| 龙游县| 阿尔山市| 婺源县|