博客
关于我
判断两个实数是否相等
阅读量:311 次
发布时间:2019-03-01

本文共 2012 字,大约阅读时间需要 6 分钟。

C程序示例:判断两个字符串表示的数字是否相等

#include 
#include
#define MAX 1000005char a[MAX], b[MAX];int main() { while (~scanf("%s%s", a, b)) { int len_a = strlen(a); int len_b = strlen(b); bool has_decimal_a = false; bool has_decimal_b = false; // 检查字符串中是否包含小数点 for (int i = 0; i < len_a; i++) { if (a[i] == '.') { has_decimal_a = true; break; } } for (int i = 0; i < len_b; i++) { if (b[i] == '.') { has_decimal_b = true; break; } } // 如果字符串中没有小数点,添加小数点 if (!has_decimal_a) { a[len_a] = '.'; } if (!has_decimal_b) { b[len_b] = '.'; } // 比较字符串的长度,补零到较短的字符串 if (strlen(a) < strlen(b)) { // 如果a没有小数点,补零从小数点后第一位开始 if (!has_decimal_a) { for (int i = len_a + 1; i < strlen(b); i++) { a[i] = '0'; } } else { // 如果a有小数点,补零从小数点后第一位开始 for (int i = len_a; i < strlen(b); i++) { a[i] = '0'; } } } else if (strlen(a) > strlen(b)) { // 如果b没有小数点,补零从小数点后第一位开始 if (!has_decimal_b) { for (int i = len_b + 1; i < strlen(a); i++) { b[i] = '0'; } } else { // 如果b有小数点,补零从小数点后第一位开始 for (int i = len_b; i < strlen(a); i++) { b[i] = '0'; } } } // 比较两个字符串是否相等 if (strcmp(a, b) == 0) { printf("YES\n"); } else { printf("NO\n"); } } return 0;}

说明:这段代码实现了一个简单的字符串比较功能,主要用于判断两个字符串表示的数字是否相等。程序首先读取两个字符串,并检查它们是否包含小数点。如果字符串中没有小数点,程序会在末尾添加小数点。然后,程序会根据字符串的长度补零到较短的字符串,使其与较长的字符串长度相同。最后,程序比较两个字符串是否相等,并输出结果。

这个程序适用于处理类似的问题,比如比较两个数是否相等,无论它们是整数还是带有小数点的浮点数。程序通过检查小数点的存在情况和字符串的长度,确保数字的准确性和比较的有效性。

转载地址:http://ysto.baihongyu.com/

你可能感兴趣的文章
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>
MySQL为Null会导致5个问题,个个致命!
查看>>
MySQL为什么不建议使用delete删除数据?
查看>>
MySQL主从、环境搭建、主从配制
查看>>
Mysql主从不同步
查看>>
mysql主从同步及清除信息
查看>>
MySQL主从同步相关-主从多久的延迟?
查看>>
mysql主从同步配置方法和原理
查看>>
mysql主从复制 master和slave配置的参数大全
查看>>