L1-017:到底有多二

题目描述

一个整数"犯二的程度 "定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。


输入格式:

输入第一行给出一个不超过50位的整数N


输出格式:

在一行中输出N犯二的程度,保留小数点后两位。


输入样例:

复制代码
-13142223336

输出样例:

复制代码
81.82%

分析

因为输入的数是不超过50位的,因此要借助字符数组来存储这个整数N。

程序代码

cpp 复制代码
#include<stdio.h>
#include<string.h>
int main(){
	char a[50];
	double t;
	int count=0;
	scanf("%s",a);
	int x=strlen(a);//测量该整数的位数
	for(int i=0;i<x;i++){//找出这个整数有几个2
		if(a[i]=='2'){
			count++;
		}
	}
	if(a[0]=='-'){//判断是否为负数
		t=(double)count/(x-1)*1.5;
		if((a[x-1]-'0')%2==0)//判断是否为偶数
	    t=t*2;
	}
	else{
		t=(double)count/x;
	if((a[x-1]-'0')%2==0)
	t=t*2;
}
	printf("%.2lf%%",t*100);//输出相应的结果
	return 0;
}

运行结果

相关推荐
superman超哥8 小时前
仓颉语言中元组的使用:深度剖析与工程实践
c语言·开发语言·c++·python·仓颉
LYFlied8 小时前
【每日算法】LeetCode 153. 寻找旋转排序数组中的最小值
数据结构·算法·leetcode·面试·职场和发展
唐装鼠8 小时前
rust自动调用Deref(deepseek)
开发语言·算法·rust
ytttr8739 小时前
MATLAB基于LDA的人脸识别算法实现(ORL数据库)
数据库·算法·matlab
charlie1145141919 小时前
现代嵌入式C++教程:C++98——从C向C++的演化(2)
c语言·开发语言·c++·学习·嵌入式·教程·现代c++
雨季余静9 小时前
c语言 gb2312转utf-8,带码表,直接使用。
c语言·c语言utf8·c语言gb2312·c语言gbk·c语言gb18030·gb2312转utf8·gbk转utf8
2401_8904430210 小时前
Linux 基础IO
linux·c语言
jianfeng_zhu11 小时前
整数数组匹配
数据结构·c++·算法
smj2302_7968265211 小时前
解决leetcode第3782题交替删除操作后最后剩下的整数
python·算法·leetcode
LYFlied12 小时前
【每日算法】LeetCode 136. 只出现一次的数字
前端·算法·leetcode·面试·职场和发展