C语言PAT刷题 - 1016 部分A+B

作者的话:若有朋友复制代码去PAT试着运行遇到问题的:
1.可能是格式问题,可以先把从本站复制的代码粘贴到记事本,再把记事本里的代码复制,然后粘贴到PAT的代码区,提交本题回答,应该就可以了;
2.可能是注释原因,PAT有时候检测到注释会编译错误,所以可以先把注释删了,再进行提交回答。
3.可能是作者当初根据题目写出来的代码仍存在一些疏漏,而恰好当时的测试机制没那么完善,没检测出问题。后面测试机制有所更新,故出现问题,若有相关需要的可以评论区留言或私信作者,我看到的话会去再查一下疏漏之处,然后更新文章。

一、题目描述
正整数A的“DA(为 1 位整数)部分”定义为由 A 中所有 DA组成的新整数 PA。例如:给定A=3862767,DA=6,则A的“6部分”PA​是 66,因为 A 中有 2 个 6。
现给定 A、DA、B、DB,请编写程序计算PA+PB
输入格式:
输入在一行中依次给出 A、DA、B、DB,中间以空格分隔,其中 0<A,B<109
输出格式:
在一行中输出 PA +PB的值。
输入样例 1:
3862767 6 13530293 3
输出样例 1:
399
输入样例 2:
3862767 1 13530293 8
输出样例 2:
0
二、解题思路
读题:
给一个数A,且DA是一个1位整数。A中有几个位上的数是DA,定义PA就等于这些DA组成的新数。如A=123123,DA=1,A中有两个1,所以PA=11。
当A中1个DA都没有的时候,PA为0。现在需要有一个程序,接收A、DA、B、DB,要求计算PA+PB的值并输出。
思路:
1.定义需要的变量(实际解题时是先定义认为需要用到的变量,后面遇到问题需要新定义变量时再回到上头来定义新的变量),从键盘接收A、DA、B、DB存入变量a,da,b,db中;
2.设置循环检测A、B的每一位,检测到符合条件的位变量count++;
3.最终利用count1和count2计算出PA、PB,最后二者相加即可。
三、具体实现
0.标准C源程序框架

#include <stdio.h>
int main()
{
	return 0;
}

1.定义需要的变量(实际解题时是先定义认为需要用到的变量,后面遇到问题需要新定义变量时再回到上头来定义新的变量),从键盘接收接收A、DA、B、DB存入变量a,da,b,db中;

    int a, da, b, db, pa = 0, pb = 0;
    int count1=0, count2=0;
    scanf("%d%d%d%d", &a, &da, &b, &db);

2.设置循环检测A、B的每一位,检测到符合条件的位变量count++;

    while (a / 10 != 0)  //a/10不为0说明他至少是两位数,检测继续进行;
    {                    //为0时说明只剩下最后一位了,结束循环,循环结束之后再最后检测一次
        if (da == a % 10)//符合条件则count1++,反之则啥也不发生,继续检测下一位
        {
            count1++;
        }
        a /= 10;
    }
    count1 += (da == a );  //关系表达式为真(a的最后一位等于da),表达式结果为1,count1加上1,反之,则加0
    while (b / 10 != 0)
    {
        if (db == b % 10)
        {
            count2++;
        }
        b /= 10;
    }
    count2 += (db == b );

3.最终利用count1和count2计算出PA、PB,最后二者相加即可。

    while (count1--)
    {
        pa = 10 * pa + da;
    }
    while (count2--)
    {
        pb = 10 * pb + db;
    }
    printf("%d", pa + pb);

四、全部代码

#include <stdio.h>
int main()
{
    int a, da, b, db, pa = 0, pb = 0;
    int count1=0, count2=0;
    scanf("%d%d%d%d", &a, &da, &b, &db);
    while (a / 10 != 0)
    {
        if (da == a % 10)
        {
            count1++;
        }
        a /= 10;
    }
    count1 += (da == a);
    while (b / 10 != 0)
    {
        if (db == b % 10)
        {
            count2++;
        }
        b /= 10;
    }
    count2 += (db == b);
    while (count1--)
    {
        pa = 10 * pa + da;
    }
    while (count2--)
    {
        pb = 10 * pb + db;
    }
    printf("%d", pa + pb);
    return 0;
}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值