摄氏度与华氏度的转换公式为C=(F-32)*5/9。

不少人看到这样的转换公式就会将摄氏度C和华氏度F定义成浮点数类型的变量。

然后采用C语言编写

C=(F-32)*5/9的语句进行转换。

如果在带有浮点数高级处理器上运算、或者是对实时性没有要求,不在乎该转换所耗费的时间,则没有任何问题。

但是如果该程序运行在普通的单片机,而且该单片机除了要进行转换之后,还有其它实时性要求高的任务需要处理。比如需要快速进行故障判断并进行保护,或者是需要进行通信数据处理,快速响应。

比如需要进行输出短路的保护判断,有些输出的短路可能需要在几百us内进行保护,否则可能损坏器件,如果该转换耗时几ms以上,可能就会导致响应不及时,造成器件损坏。

所以当程序运行在普通的单片机时,我们还需要考虑该单片机是否支持硬件的浮点数运算,甚至要考虑是否有硬件的乘法器。

普通的单片机不支持硬件浮点数运算,浮点数的四则运算可能需要软件算法实现,会花费大量的时间。

这种情况,我们可以根据精度和量程要求,放缩之后,将C和F定义为整型的变量,再进行运算。

比如,如果我们取1位小数的精度,量程为100摄氏度,

则可以将C和F定义为16位的整型,采用下列的程序进行转换;

signed short C, F;

C=(F-32)*50/9。

早期的Microchip的PIC16F,PIC18F系列的处理器,没有硬件乘除法器,进行乘除法运算,都需要通过软件算法实现,可能耗费几十ms的时间。

这种情况我们可以通过加法和移位操作实现;

*5/9约等于36408/65536=(32768+2048+1024+512+32+16+8)/65536;

将C定义为32位的整型。

signed int C, d1,d2;

d1=F-32;

d2=d1 << 3;//*8

d1 = d1 <<1;//*16

d2 += d1;

d1 = d1 << 1;//*32;

d2 += d1;

d1 = d1 << 5;//*512;

d2+= d1;

d1 = d1 << 1;//*1024;

d2 += d1;

d1 = d1 << 4; //*32768

d2+= d1;

C=d2>>16;

这样可以大大节省转换时间。

首先,我们要理解需求,就像你问的“摄氏度与华氏温度如何转换”,然后就是设计,简单点就是使用怎样的公式算法来解决问题,

“摄氏温标”是经验温标之一,亦称“百分温标”。温度符号为t,单位是摄氏度,国际代号是“℃”

华氏温标”是经验温标之一。在美国的日常生活中,多采用这种温标。规定在一大气压下水的冰点为32度,沸点为212度,两个标准点之间分为180等分,每等分代表1度。华氏温度用字母“F”表示。它与摄氏温度(C)和之间的换算关系为F=9/5c+32, 或C=5/9(F-32)。

现在转换公式已经有了,就是编码实现了。

代码:

#include <stdio.h>

int main(void)

{

float F,C;

print(华氏度--摄氏度转换器\n)

printf(请输入您需要转换的华氏温度:);

scanf(%f,&F);

C = (F-32)*5/9.0;

printf(其对应的摄氏温度为:%.2f \n,C);

return 0;

}