c语言 从键盘输入两个正实数,位数不超过200,试判断这两个实数是否完全相等。注意输入的实数整数部分可能有前导0,小数部分可能有末尾0。
时间: 2024-09-26 12:16:10 浏览: 95
在C语言中双精度浮点数线性化相等比较的研究.pdf
在C语言中,判断两个实数是否完全相等,我们需要先读取用户的输入,并将其转换为浮点数。由于涉及到字符串处理和浮点数比较,可以按照以下步骤操作:
1. 使用`scanf`函数从键盘读入两个字符串,分别表示两个实数,格式化字符串可以指定最多读取200个字符,例如:`char str1[201], str2[201];`
2. 确保输入的是有效的数字,需要检查每个字符串是否只包含数字(包括'.'作为小数点)以及可能的前导和尾随的零。可以遍历字符串,如果遇到非数字字符则跳出循环。
3. 将字符串转换为浮点数。C语言本身没有直接将字符串转为浮点的函数,但可以借助`strtol`函数获取整数部分,然后加上小数点后的部分。需要注意处理小数点的位置和精度。
4. 比较两个浮点数是否相等。由于浮点数可能会有微小的精度误差,通常我们使用`fabs(a - b) < ε`这样的条件来判断,其中`a`和`b`是待比较的浮点数,`ε`是一个非常小的正数。
下面是一个简单的示例代码片段:
```c
#include <stdio.h>
#include <string.h>
#include <math.h>
int is_number(char *s) {
while (*s && *s >= '0' && *s <= '9') s++;
return (*s == '.') || !*s;
}
double atof_custom(char *str) {
int pos = 0, neg = 0;
if (*str == '-') {
neg = 1;
str++;
}
while (is_number(str)) {
pos *= 10;
pos += (str[0] - '0');
str++;
}
if (*str == '.') {
str++;
double frac = 0.1;
while (is_number(str)) {
frac *= 10;
frac += (str[0] - '0');
str++;
}
return neg ? -frac + pos : pos + frac;
} else {
return neg ? -pos : pos;
}
}
int main() {
char str1[201], str2[201];
printf("请输入第一个实数(最多200位):");
fgets(str1, sizeof(str1), stdin);
str1[strcspn(str1, "\n")] = '\0'; // 移除换行符
printf("请输入第二个实数(最多200位):");
fgets(str2, sizeof(str2), stdin);
str2[strcspn(str2, "\n")] = '\0';
double a = atof_custom(str1);
double b = atof_custom(str2);
if (fabs(a - b) < DBL_EPSILON) {
printf("两个实数完全相等。\n");
} else {
printf("两个实数不完全相等。\n");
}
return 0;
}
```
阅读全文