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;
}

运行结果

相关推荐
TechQuester17 分钟前
解决GPT-4o耗电难题!DeepMind新算法训练效率提升13倍,能耗降低10倍!
java·c++·人工智能·python·算法·chatgpt
流星白龙25 分钟前
【C语言题目】34.猜凶手
c语言·开发语言
XSTIT25 分钟前
数据结构--二叉树相关题2(OJ)
数据结构·算法
观鉴词recommend33 分钟前
【c++刷题笔记-动态规划】day32: 509. 斐波那契数 、 70. 爬楼梯 、 746. 使用最小花费爬楼梯
c++·笔记·算法·leetcode·动态规划
不决问春风39 分钟前
102.二叉树的层序遍历——二叉树专题复习
java·算法·leetcode
chem411141 分钟前
C语言4 运算符
c语言·开发语言
郝YH是人间理想1 小时前
《算法笔记》总结No.3——排序
c语言·数据结构·c++·算法·排序算法·csp
a_golden_fish1 小时前
【做一道算一道】滑动窗口最大值
数据结构·算法
凢曐1 小时前
水仙花数算法
算法
creative_mind1 小时前
优选算法之技巧(一):双指针一:移位0与复写0
数据结构·算法·优选算法