大学物理实验代码

  *大学物理实验代码*
   这是有关大学物理实验的计算代码,不算太复杂,有需要的人可以拿去用。
   我个人认为呢,将c语言与课程结合是很好的事,可以熟练代码,也可以方便自己。
   代码如下
#include<stdio.h>
#include<math.h>
#define PI 3.1415926
int fun1(float a,float b,float c,float d,float e);//标准差计算
void fun2();
void fun3();
void fun4();
void fun5();
void fun6();
int main()
{   int a;
    printf("请输入一个数字,如果数字=1,那么计算标准差\n");
    printf("如果数字=2,那么计算根据k计算普朗克常量和绝对误差\n");
    printf("如果数字=3,那么计算超声波速度\n"); 
    printf("如果数字=4,那么计算卧式电桥\n");
    printf("如果数字=5,那么计算液体表面张力及表面张力系数\n");
    printf("假如数字=6,就计算平均数\n");
    scanf("%d",&a);
    if(a==1)
    {
	float a,b,c,d,e;
	printf("请输入构成标准差的数字\n"); 
	scanf("%f%f%f%f%f",&a,&b,&c,&d,&e);
	fun1(a,b,c,d,e);
    }
    if(a==2)
    fun2();
    if(a==3)
    fun3();
    if(a==4)
    fun4();
    if(a==5)
    fun5();
    if(a==6)
    fun6();
    return 0;
}



int fun1(float a,float b,float c,float d,float e)//标准差计算
{
	float u,t;//u为平均值,t为平方差的积 
	float y;
    u=(a+b+c+d+e)/5;
	t=(a-u)*(a-u)*(b-u)*(b-u)*(c-u)*(c-u)*(d-u)*(d-u)*(e-u)*(e-u);
	y=sqrt(t/5);
	printf("标准差为%.2f",y);
	return 0;  
}
void fun2()//普朗克常量的测量以及绝对误差的计算 
{
	double k;
	printf("请输入斜率k,k对应的自变量v单位为10的14次方赫兹\n"); 
	scanf("%lf",&k);
	k=k*pow(10,-14);
	double e=1.602*pow(10,-19),h,h1;
	h=e*k;
	h1=h*pow(10,34);
	printf("普朗克常量乘与10的34次方是%lf",h1); 
	double h0=6.626*pow(10,-34),E;
	E=fabs(h-h0)/h0;//fabs是求浮点数绝对值的函数
	printf("绝对误差是E=%lf",E);
}
void fun3()//超声波速度的测量 
{
	float l[6],L,sum;
	int i;
	printf("请输入逐差法得到的6个delta x");
	for(i=0;i<=5;i++)
	{
	scanf("%f",&l[i]);
	sum+=l[i];
    }
    L=sum/6;
	float bochang,f=215.548*1000,v;
	bochang=2L*0.001;
	printf("波长为%.2lf",bochang);
	v=bochang*f; 
	printf("声速为%.2f",v);
 } 
 void fun4()
 {
 	double y,u;
	double 	R=54;
	printf("请输入u(单位是mV)\n");
	scanf("%lf",&u);
	y=(4*u*0.001/(3-2u*0.001))*R;
	printf("卧式电桥deta R的运算结果为%.2f",y);
 }
 void fun5()
 {
 	float a,f,L;
    float D1,D2;
    float k,U;
    printf("请输入内径D1外径D2,k以及表面张力对应读数平均值U\n");
    scanf("%lf%lf%lf%lf",&D1,&D2,&k,&U);
    L=PI*(D1+D2);
    f=U*k; 
    a=2*f/L;
    printf("表面张力f=%.2lf 表面张力系数=%.2lf",a);//隔了很久才发现漏了一个参数,
                                                  //不清楚是什么,看着填吧
 }
 void fun6()
 {
 	int n,i;
    printf("请输入数字个数n按回车 \n 再输入数字n1,n2,...\n ");
    scanf("%d\n",&n);
    float a[n],sum;
    for(i=0;i<=n-1;i++)
    {   scanf("%f",&a[i]);
        sum+=a[i];
    }
    printf("平均值为%.2f",sum/n);
 }
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值