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

运行结果

相关推荐
NAGNIP10 分钟前
主流的激活函数有哪些?
算法
NAGNIP12 分钟前
Self-Attention 为什么要做 QKV 的线性变换?又为什么要做 Softmax?
算法
core51228 分钟前
PageRank 算法:互联网的“人气投票”
算法·pagerank
小白菜又菜31 分钟前
Leetcode 1523. Count Odd Numbers in an Interval Range
算法·leetcode
你们补药再卷啦1 小时前
人工智能算法概览
人工智能·算法
cnxy1881 小时前
围棋对弈Python程序开发完整指南:步骤3 - 气(Liberties)的计算算法设计
python·算法·深度优先
AndrewHZ1 小时前
【图像处理基石】什么是光栅化?
图像处理·人工智能·算法·计算机视觉·3d·图形渲染·光栅化
小白菜又菜1 小时前
Leetcode 944. Delete Columns to Make Sorted
算法·leetcode
Alex Cafu2 小时前
Linux网络编程1(OSI模型与TCP/IP协议栈)
linux·c语言·网络·tcp/ip
博语小屋2 小时前
转义字符.
c语言·c++