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

运行结果

相关推荐
一只鱼^_7 分钟前
牛客周赛 Round 105
数据结构·c++·算法·均值算法·逻辑回归·动态规划·启发式算法
是阿建吖!8 分钟前
【动态规划】斐波那契数列模型
算法·动态规划
啊阿狸不会拉杆36 分钟前
《算法导论》第 27 章 - 多线程算法
java·jvm·c++·算法·图论
火车叨位去194942 分钟前
力扣top100(day04-05)--堆
算法·leetcode·职场和发展
数据智能老司机43 分钟前
面向企业的图学习扩展——面向图的传统机器学习
算法·机器学习
类球状1 小时前
顺序表 —— OJ题
算法
Miraitowa_cheems2 小时前
LeetCode算法日记 - Day 11: 寻找峰值、山脉数组的峰顶索引
java·算法·leetcode
CoovallyAIHub2 小时前
方案 | 动车底部零部件检测实时流水线检测算法改进
深度学习·算法·计算机视觉
CoovallyAIHub2 小时前
方案 | 光伏清洁机器人系统详细技术实施方案
深度学习·算法·计算机视觉
lxmyzzs2 小时前
【图像算法 - 14】精准识别路面墙体裂缝:基于YOLO12与OpenCV的实例分割智能检测实战(附完整代码)
人工智能·opencv·算法·计算机视觉·裂缝检测·yolo12