博客
关于我
判断两个实数是否相等
阅读量: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 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>
mysql 的存储引擎介绍
查看>>
MySQL 的存储引擎有哪些?为什么常用InnoDB?
查看>>
mysql 索引
查看>>
MySQL 索引失效的 15 种场景!
查看>>
MySQL 索引深入解析及优化策略
查看>>
MySQL 索引的面试题总结
查看>>
mysql 索引类型以及创建
查看>>
MySQL 索引连环问题,你能答对几个?
查看>>
Mysql 索引问题集锦
查看>>
Mysql 纵表转换为横表
查看>>
mysql 编译安装 window篇
查看>>
mysql 网络目录_联机目录数据库
查看>>
MySQL 聚簇索引&&二级索引&&辅助索引
查看>>