使用c语言,一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。
时间: 2024-03-25 18:36:57 浏览: 91
给定2到15个不同的正整数,你的任务是计算这些数里面有多少个数对满足:数对中一个数是另一个数的两倍。
明白了,下面是一个C语言程序,可以计算一个整数的犯二程度:
```c
#include <stdio.h>
#include <stdlib.h>
int main()
{
long long int num;
int count = 0, digits = 0;
double degree;
printf("请输入一个整数:");
scanf("%lld", &num);
if (num < 0) {
degree = 1.5;
num = -num;
} else {
degree = 1.0;
}
while (num) {
digits++;
if (num % 10 == 2) count++;
num /= 10;
}
if (digits % 2 == 0) degree *= 2.0;
degree *= (double)count / (double)digits * 100.0;
printf("这个整数的犯二程度为:%.2f%%\n", degree);
return 0;
}
```
程序中使用了long long int类型来读取整数,可以处理较大的数字。首先判断是否为负数,如果是则将程度增加1.5倍。然后统计数字中2的个数和位数。如果位数为偶数,则将程度再增加1倍。最后计算犯二程度并输出结果。
阅读全文