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

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

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

2019-11-11 00:20:03
字體:
來源:轉載
供稿:網友

題目鏈接在此。

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

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 贞丰县| 岑巩县| 绥芬河市| 乃东县| 西吉县| 昌吉市| 肃宁县| 庆阳市| 常宁市| 商丘市| 迁西县| 金溪县| 鄂伦春自治旗| 平谷区| 宝丰县| 凌源市| 苗栗市| 磐石市| 江川县| 娱乐| 太仆寺旗| 苍南县| 政和县| 崇州市| 洞口县| 芮城县| 高密市| 商城县| 维西| 比如县| 漳平市| 小金县| 黄浦区| 名山县| 阜阳市| 灌南县| 常熟市| 汤原县| 根河市| 绥芬河市| 二连浩特市|