| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3405 人关注过本帖
标题:求大神解答,是关于求物理数据的不确定度
只看楼主 加入收藏
rapidlaser
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2016-3-29
收藏
 问题点数:0 回复次数:0 
求大神解答,是关于求物理数据的不确定度
#include<iostream>
#include<cmath>
using namespace std;
double g0(int n,int a)//调用数据g0
{double g0;switch(n*a)
{case 4:g0=1.49; break;
 case 5:g0=1.75; break;
 case 6:g0=1.94;break;
 case 7:g0=2.10;break;
 case 8:g0=2.22;break;
case 9:g0=2.32;break;
case 10:g0=2.41;break;
case 11:g0=2.48;break;
case 12:g0=2.55;break;
case 20:g0=1.45;break;
case 25:g0=1.67;break;
case 30:g0=1.82;break;
case 35:g0=1.94;break;
case 40:g0=2.03;break;
case 45:g0=2.11;break;
case 50:g0=2.18;break;
case 55:g0=2.23;break;
case 60:g0=2.28;break;
default:cout<<"增加库存信息"<<endl;
}return g0;
}

int main()
{int a,n;double x,g,u1,u2,u,m,ave;
cout<<"如果a是0.01输入1,是0.05输入5"<<endl;
cin>>a;
cout<<"仪器的误差为"<<endl;
cin>>m;
cout<<"输入数据个数n"<<endl;
cin>>n;
double *b=new double[n];
while(n)
{int i=0;cout<<"输入一个数据"<<endl;
cin>>x;
b[i]=x;
i++;n--;
}delete []b;
double sum1=0;ave=0;for(int i=0;i<=(n-1);i++) sum1+=b[i];ave=sum1/n;
double sum2=0,s=0;for(int i=0;i<=(n-1);i++) sum2+=(b[i]-ave)*(b[i]-ave);

s=sqrt(sum2/(n-1));
for(int i=0;i<=(n-1);i++)
{    g=fabs(b[i]-ave)/s;
if(g>g0(n,a))
{int i; b[i]=0;
n--;}
for(int i=0;i<=(n-1);i++) sum1+=b[i];ave=sum1/n;
for(int i=0;i<=(n-1);i++) sum2+=(b[i]-ave)*(b[i]-ave);s=sqrt(sum2/(n-1));
u1=s/sqrt((double)n);
u2=m/sqrt((double)3);
u=sqrt(u1*u1+u2*u2);
cout<<"不确定度为="<<u<<endl;
}
}

为什么输入数据后得不到结果,直接结束了
搜索更多相关主题的帖子: include double 
2016-04-20 19:29
快速回复:求大神解答,是关于求物理数据的不确定度
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020443 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved