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

运行结果

相关推荐
QT 小鲜肉3 分钟前
【QT/C++】Qt网络编程进阶:TCP网络编程的基本原理和实际应用(超详细)
c语言·开发语言·网络·c++·qt·学习·tcp/ip
墨染点香2 小时前
LeetCode 刷题【144. 二叉树的前序遍历】
数据结构·算法·leetcode
cynicme7 小时前
力扣3318——计算子数组的 x-sum I(偷懒版)
java·算法·leetcode
ACP广源盛139246256739 小时前
(ACP广源盛)GSV6172---MIPI/LVDS 信号转换为 Type-C/DisplayPort 1.4/HDMI 2.0 并集成嵌入式 MCU
c语言·开发语言·单片机·嵌入式硬件·音视频
im_AMBER10 小时前
算法笔记 09
c语言·数据结构·c++·笔记·学习·算法·排序算法
凯芸呢10 小时前
Java中的数组(续)
java·开发语言·数据结构·算法·青少年编程·排序算法·idea
寂静山林10 小时前
UVa 1030 Image Is Everything
算法
AI柠檬10 小时前
几种排序算法的实现和性能比较
数据结构·算法·c#·排序算法
weixin_4296302611 小时前
第6章 支持向量机
算法·机器学习·支持向量机
SweetCode11 小时前
C++ 实现大数加法
开发语言·c++·算法