博客
关于我
判断两个实数是否相等
阅读量: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 InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
mysql problems
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>