博客
关于我
判断两个实数是否相等
阅读量: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当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>
mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
查看>>
mysql性能优化
查看>>
mysql性能优化学习笔记-存储引擎
查看>>
MySQL性能优化必备25条
查看>>
Mysql性能优化(1):SQL的执行过程
查看>>
Mysql性能优化(2):数据库索引
查看>>
Mysql性能优化(3):分析执行计划
查看>>
Mysql性能优化(4):优化的注意事项
查看>>
Mysql性能优化(5):主从同步原理与实现
查看>>
Mysql性能优化(6):读写分离
查看>>
MySQL性能优化(八)--
查看>>
MySQL性能测试及调优中的死锁处理方法
查看>>