6-9 统计个位数字

本题要求实现一个函数,可统计任一整数中某个位数出现的次数。例如-21252中,2出现了3次,则该函数应该返回3。

函数接口定义:

int Count_Digit ( const int N, const int D );

其中N和D都是用户传入的参数。N的值不超过int的范围;D是[0, 9]区间内的个位数。函数须返回N中D出现的次数。

此种方法 较简单,使用三目运算符
#include <stdio.h>
int Count_Digit ( const int N, const int D );
int main()
{
    int N, D;
    scanf("%d %d", &N, &D);
    printf("%d\n", Count_Digit(N, D));
    return 0;
}

int Count_Digit ( const int N, const int D )
{
  int count=0;
  int n=N>0?N:-N;
  int a;
  do{
  	a = n%10;
  	if(a==D) count++;
  	n=n/10;
  } while(n);
  return count;
}
第二种也是我自己写的方法,较常规任意理解,使用绝对值函数,对于为0的情况单独讨论
#include <stdio.h>
int Count_Digit ( const int N, const int D );
int main()
{
    int N, D;
    scanf("%d %d", &N, &D);
    printf("%d\n", Count_Digit(N, D));
    return 0;
}

int Count_Digit ( const int N, const int D )
{
	int a = 0;
	int n = N;
	int count=0;
	if (n==0)
	{
		count = 1;
	}
	while(n)
	{
		a = abs(n%10);
		if(a==D)
		{
			count++;
		}
			n = n/10;
	 }
	 return count;
}
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值