【C语言及程序设计】项目1-4-2-2:计算并联电阻

C语言程序设计初步 专栏收录该内容
5 篇文章 0 订阅
/* 并联电阻值.cpp: 
问题描述:编程序,输入两个电阻R1和R2的阻值,求它们并联后的阻值R。提示:计算公式为r=1/(1/r1+1/r2));电阻值为浮点数
*/

#include "stdafx.h"
#include <iostream>
using namespace std;


int main()
{
	int R1, R2, Ro;
	
	printf("Input the value of the paralleled resistor R1 and R2");
	scanf_s("%d %d", &R1, &R2);

	Ro = (float)(1 / (1.0 / R1 + 1.0 / R2));

	cout << Ro;
	//printf("The value of the paralleled resistor R1 and R2 as a whole is %d", Ro);

    return 0;
}

感想:

这题对于初学者而言,看似再简单不过,但实际暗藏杀机。“杀机”在于上方code中,17行中的隐性/自动数据类型转换(“隐性转换”)

	Ro = (float)(1 / (1.0 / R1 + 1.0 / R2));

项目1-4-2-4中也提到了这个问题:隐性转换时发生的数据丢失(但为什么分配更大的存储单元会丢失?

C语言支持不同数据类型的value/variable间的相互运算,每运算一次,都会发生隐性转换,而这种运算就是通过隐性转换得以实现的,其规则为


例如 

1+2的结果,仍然是int型;

3.28+3.24e5的结果,仍然是double型;


这个规则要用,每次定义变量都需要给定的 数据类型 的本质,加以理解:

一个变量,在内存中占据一定的存储单元;

通过变量名,找到对应的存储单元,从而操作变量的值。

也就是说,定义数据类型/给定变量名,实质是数据类型与存储空间之间的映射(规则),如下图:


可见,隐性转换的规则是,给每次计算的输出值分配更大的储存空间

但是有意思的是,

	Ro = (float)(1 / (1.0 / R1 + 1.0 / R2));

其中 = 运算,也发生了数据类型转换:将float类型的数值,赋给int类型的变量,最终输出的数据类型依然是int类型。最初给定的类型统辖着最终结果。

 

  • 1
    点赞
  • 0
    评论
  • 2
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

参与评论 您还未登录,请先 登录 后发表或查看评论
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页

打赏作者

tinym

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值