waixiong 发表于 2021-9-25 18:26:51

c语言运算问题

#include <stdio.h>
int main()
{
        float c,f;
        scanf("%f",&f);
        c =(5/9)*(f-32);
        printf("%f",c);
        return 0;
}
有两个疑惑:
1.flaot 是不是一定要有一个小数?
2.c语言中的运算顺序如何排列?
谢谢!

daoshuai 发表于 2021-9-25 18:26:52

你好,你这个代码运行结果是0是因为你用的5/9   这样的话得出的是0,如果是5.0/9.0才是有小数的,整数相除(5、9都是整数 即 int 型)得到的是整数,结果小于0就直接等于0了,比如·9/5=1,余数是4,10/8=1,余数是2。不一定非要有小数,这是你的公式存在一些问题。
2.也是加减乘除的优先级,先乘除然后加减,有括号先算括号的   

万千只cnm 发表于 2021-9-25 19:37:26

1. 不一定呀
2 http://c.biancheng.net/cpp/html/462.html

MZZ666 发表于 2021-9-25 20:13:23

1.你是不是想问一定要有小数点吗?可以省略不屑,比如folat a=1;就表示a是1.0.
2.运算顺序你得看运算符得优先级,就是先乘除后加减啥的,()得优先级最高。

bszs 发表于 2021-9-26 00:47:05

楼上正解

Mangata09 发表于 2021-9-26 01:07:11

1.是的,有小数点就是用float(你打错了哦)3.1415
但是如果小数点位数太多的话就用长一点的字符:double3.1415926...........

2.程序中++ --自增自减运算符高于其他计算运算符
详情可以看小甲鱼的拓展阅读:运算符的优先级和结合 免费的哦

茕茕孑立7023 发表于 2021-9-26 12:45:00

可以把5/9改成5.0/9或5/9.0或5.0/9.0,转化为浮点型

a327904410 发表于 2021-9-26 14:34:16

float可以是小数也可以不是小数,但float输出一定有小数,比如输入2输出2.0000

大龄龄 发表于 2021-9-26 19:16:33

1.一定要有一个小数
2.!> 算术运算符 > 比较运算符 > && >|| > 赋值运算符

18476040601 发表于 2021-9-26 19:56:09

本帖最后由 18476040601 于 2021-9-26 20:00 编辑

1. 不一定要有小数,float型,就算输入3,也会以3.0的方式运算
2. 各语言运算符的优先级我有一个整理好的word文档,这是我整理好的帖子
各热门语言运算符优先级
https://fishc.com.cn/thread-202983-1-1.html
(出处: 鱼C论坛)

番杰 发表于 2021-9-29 17:32:31

本帖最后由 番杰 于 2021-9-29 17:34 编辑

1.不一定哦
(1)除数和被除数有一个是小数;
       例如:1.0/2结果为0.5;

(2)使用了浮点类型进行定义:
      例如:float i;
                i = 1/2;
                i 的结果还是会为0.5;
                因为定义了i的数据类型,
                尽管写入的是1/2;
                但是在编译器看了则是1.0/2.0。

2.请点击这里:运算符优先级
页: [1]
查看完整版本: c语言运算问题