PAT (Basic Level) Practice 1016 部分A+B
题目
正整数 A 的“DA (为 1 位整数)部分”定义为由 A 中所有 DA 组成的新整数 PA 。例如:给定 A=3862767,DA =6,则 A 的“6 部分”PA 是 66,因为 A 中有 2 个 6。现给定 A、DA 、B、DB ,请编写程序计算 PA +PB 。
方法一
#include "stdio.h"
#include "math.h"
#include "string.h"
int count(char *a,int key)
{
int i,n=0;
for(i=0;i<strlen(a);i++)
{
if(a[i]-'0'==key) n++ ;
}
printf("%d",n);
return n;
}//计算key的数量
int tran(int n,int key){
return (pow(10,n)-1)/9*key;}//利用(10^n-1)=111…1的思想
int main()
{
char a[11],b[11];
int n1,n2,i;
scanf("%s %d %s %d",a,&n1,b,&n2);
printf("%d",tran(count(a,n1),n1)+tran(count(b,n2),n2));
return 0;
}
方法二
类似于进制转换
long int a;
int n1;
scanf("%ld %d",&a,&n1);
long int s1=0,k=1;
while(a)
{
if(a%10==n1)
{
s1=k*n1;
k=10*k;
}
a=a/10;
}
另:关于字符串减’0’得整数
在字符串中原本储存的’0’对应的ASCII码为48,输出的a[i]则为a[i]+48。
想要得到字符串中的数字,应将a[i]-'0’或者a[i]-48。
#include "stdio.h"
#include "string.h"
int main()
{
char a[11]="12345";
int i,n=0;
for(i=0;i<strlen(a);i++)
printf("%d ",a[i]);
return 0;
}