其他分享
首页 > 其他分享> > PAT之部分A+B

PAT之部分A+B

作者:互联网

正整数 A 的“D​A​​(为 1 位整数)部分”定义为由 A 中所有 D​A​​ 组成的新整数 P​A​​。例如:给定 A=3862767,D​A​​=6,则 A 的“6 部分”P​A​​ 是 66,因为 A 中有 2 个 6。

现给定 A、D​A​​、B、D​B​​,请编写程序计算 P​A​​+P​B​​。
输入格式:

输入在一行中依次给出 A、D​A​​、B、D​B​​,中间以空格分隔,其中 0<A,B<10​10​​。
输出格式:

在一行中输出 P​A​​+P​B​​ 的值。
输入样例 1:

3862767 6 13530293 3

输出样例 1:

399

输入样例 2:

3862767 1 13530293 8

输出样例 2:

0

#include <stdio.h>
#include <string.h>
int main(){
	int i,j,k,m,n,pa,pb,da,db,l;
	char s[24];
	char sa[10];
	char sb[10];
	gets(s);
	l=strlen(s);
	i=j=k=da=db=pa=pb=0;
	
		while(s[i]!=' '&&i <l)
		{
			sa[j++]=s[i];
			i++;
		}
		
		i++;
		da=s[i++]-'0';
		i++;
		while(s[i]!=' '&&i<l)
		{
		
			sb[k++]=s[i];
			i++;
		}
		i++;
		db=s[i]-'0';
	
		for(m=0;m<j;m++)
		{
		//printf("sa %c\n",sa[m]);
			if((sa[m]-'0')==da)
			{
			
				pa=pa*10+da;
			}
		}
		for(n=0;n<k;n++)
		{
			//printf("sb %c\n",sb[n]);
			if((sb[n]-'0')==db)
			{
			
				pb=pb*10+db;
			}
		}
	
		printf("%d",pa+pb);

	return 0;
}

这题较简单,但是C语言中是否有切分字符串的函数我暂时还不清楚,还在系统学习C语言中。字符串的切分我采用暴力手段,也就是循环判断找切割点。

标签:输出,3862767,PAT,样例,13530293,char,部分,输入
来源: https://blog.csdn.net/weixin_45433525/article/details/104679165