*大学物理实验代码*
这是有关大学物理实验的计算代码,不算太复杂,有需要的人可以拿去用。
我个人认为呢,将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;
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;
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);
}