博客
关于我
判断两个实数是否相等
阅读量: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 —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>