sprintf可以精确的将float类型转换成字符马;sscanf 可以精确的转换回来吗

Arthur_ 2006-09-08 10:17:14
sprintf可以精确的将float类型转换成字符马;sscanf 可以精确的转换回来吗
我昨天作了程序结果出现上面的情况,程序刚修改过,所以没有现成的,不过大家可以试验
如果浮点类型很大564645.546897
...全文
289 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
0黄瓜0 2006-09-08
  • 打赏
  • 举报
回复
double d=0.124;
printf("%f",d);

输出:0.124000

Kvci的例子二进制位数不够,float都有23位表示底数
0黄瓜0 2006-09-08
  • 打赏
  • 举报
回复
float只有6位左右数字是精确的,
double有10位左右数字是精确的。

注意0.00001234是4位数字,不是8位,这样看:1.234e-5
Kvci 2006-09-08
  • 打赏
  • 举报
回复
浮点数占4个字长。 除了保存整数部分,还要保存小数部分。且应该是以二进制形式进行运算的。

因此,对于其小数部分的所占存储长度应该是有限的。如果刚好能表示成一个二进制小数的话,就可直接保存下来。如果不能的话,那编译器自动会取一个尽量接近的二进制小数保存下来。

比如说0.125 和0.124

0.125刚好是2的-3次方.(二进制: 0.001)

但0.124是没有准确的二进制值的

0.0001111111=0.1230468750

而0.00011111111=0.1240234375

相比之下0.00011111111=0.1240234375误差要小.,与0.124跟接近.

所以计算机就以0.00011111111=0.1240234375来保存这个小数拉

所以在机器上显示最后的会都是.124023

也就是多出的部分会一样拉

Kvci 2006-09-08
  • 打赏
  • 举报
回复
http://blog.csdn.net/Kvci/archive/2005/03/18/322750.aspx
以前有讨论着问题的拉
看我的BLOG
Arthur_ 2006-09-08
  • 打赏
  • 举报
回复
是什么问题?
将得有道理就给分
Arthur_ 2006-09-08
  • 打赏
  • 举报
回复
晕,打错了是
确实不精确
Arthur_ 2006-09-08
  • 打赏
  • 举报
回复
#include <stdio.h>

int main(void)
{
float a,b;
char str[50];
scanf("%f",&a) ;
sprintf(str,"%f",a);
sscanf(str,"%f",&b);
printf("%f\n",a); // add
printf("%f\n",b); // add
if (a==b) printf("equal");
else printf("not equal");
return 0;
}
//$ gcc -o a a.c
a.c:17:2: warning: no newline at end of file

Administrator@TEST-36F63D6B7A ~
$ a
564654.132469
564654.125000 //printf
564654.125000 //printf
equal
//=====================//
看来确实精确哦
tailzhou 2006-09-08
  • 打赏
  • 举报
回复
#include <stdio.h>

int main(void)
{
float a,b;
char str[50];
scanf("%f",&a) ;
sprintf(str,"%f",a);
sscanf(str,"%f",&b);

if (a==b) printf("equal");
else printf("not equal");

return 0;
}

我用这个测试了一些数据,都是equal;

如果sscanf用的字符串的是用sprintf初始化的,估计是可以的。

大家多测试一下??
Kvci 2006-09-08
  • 打赏
  • 举报
回复
可以
hailongchang 2006-09-08
  • 打赏
  • 举报
回复
浮点数转化为二进制的方法和整数不一样,况且浮点数所占用的字节比char占用的肯定要多,当在浮点所占内存的区域读取第一个字节时,完全可能读到一个可打印字符
内容概要:本文围绕“阶梯碳下考虑P2G-CCS与供需灵活响应的IES优化调度”展开,基于Matlab平台构建综合能源系统(IES)在阶梯式碳交易机制下的优化调度模型。研究深度融合电制气(P2G)与碳捕集、利用与封存(CCS)技术,结合需求侧灵活响应机制,旨在提升系统的低碳运行能力与经济性。通过建立多能流耦合的优化模型,协调电力、天然气、热力等多种能源形式的协同调度,有效降低系统碳排放强度,并借助YALIMIP工具包调用求解器进行高效求解。文档提供了完整的代码实现、模型构建流程与结果分析方法,涵盖从问题建模到仿真实现的全过程,具备较强的可复现性与科研参考价值。; 适合人群:具备电力系统、能源系统或优化建模相关背景的研究生、高校教师及工程技术人员,尤其适合从事综合能源系统、碳减排策略、P2G与CCS技术集研究的专业人员,需熟练掌握Matlab编程与基本的数学规划知识。; 使用场景及目标:①用于研究阶梯式碳交易政策下综合能源系统的低碳经济调度策略;②支撑P2G-CCS技术与需求响应机制在IES中的仿真集与性能评估;③作为撰写高水平学术论文(如EI/SCI收录)的技术基础与复现资源,推动碳中和背景下能源系统优化方向的创新研究。; 阅读建议:建议结合百度网盘提供的完整代码与资料包,按照模块逐步调试程序,重点理解目标函数的设计逻辑、碳交易本的建模方式、约束条件的数学表达及求解器的配置方法,同时关注多能耦合设备的建模细节,配合公众号“荔枝科研社”获取持续的技术支持与案例拓展。
内容概要:本文系统研究了基于卷积神经网络(CNN)与支持向量机(SVM)融合的CNN-SVM混合模型在数据分类预测中的应用,尤其聚焦于工业故障识别领域。通过Matlab平台实现,该方法首先利用CNN强大的多层次特征提取能力对原始输入数据进行深度特征学习,自动捕获关键局部模式与空间结构信息,随后将提取的高层特征作为输入传递至SVM分类器,借助SVM在高维空间中小样本条件下卓越的分类性能与泛化能力完最终判别任务。文中详尽阐述了模型的整体架构设计、网络参数配置、训练优化流程及特征迁移机制,充分结合了深度学习在特征表达上的优势与传统机器学习在分类决策上的稳健性。实验部分通过实际故障数据集验证了该混合模型相较于单一CNN或SVM模型在分类准确率、鲁棒性和抗过拟合能力方面的显著提升,证明了其在复杂故障诊断任务中的有效性与先进性; 适合人群:具备一定机器学习与深度学习理论基础,熟悉Matlab编程环境,从事故障诊断、模式识别、智能制造、电力系统监控或工业数据分析等相关领域的研究生、科研人员及工程技术开发者; 使用场景及目标:① 应用于旋转机械、电力设备、航空航天等领域的多类别故障识别与状态监测;② 掌握深度特征提取与传统分类器融合的技术路径,提升小样本、高噪声环境下数据分类的精度与可靠性;③ 为撰写高水平学术论文、开展科研项目或工程实践提供可复现的算法框架与完整代码支持; 阅读建议:读者应深入理解CNN与SVM的协同工作机制,重点分析特征提取层与分类层之间的接口设计,建议动手运行并调试所提供的Matlab代码,尝试在不同数据集上进行迁移实验与参数调优,以全面掌握该混合模型的应用技巧与优化策略。

70,037

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧