2013-08-30
展开全部
我用C做了一个高斯消去法:你自己去把改为C++吧··#include<stdio.h>
#define MAX 20
float gauss(int n,float x[][MAX],float y[]);
float selectmain(int k,int n,float x[][MAX],float y[]);
float sum(int n,int i,int j,float x[][MAX],float y[]);
void main()
{
int i,j,n,end=1;
float a[MAX][MAX]={};
float b[MAX]={};
while(end==1)
{
printf("input n=");
scanf("%d",&n);
printf("input a[%d][%d]=",n,n);
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
scanf("%f",&a[i][j]);
}
}
printf("input b[%d]=",n);
for(i=1;i<=n;i++)
{
scanf("%f",&b[i]);
}
gauss(n,a,b);
printf("输入end的值(1代表继续输入/0代表结束)");
scanf("%d",&end);
}
exit(0);
}
float gauss(int n,float a[][MAX],float b[])
{
int i,j,k;
for(k=1;k<=n;k++)
{
selectmain(k,n,a,b);
for(j=k+1;j<=n;j++)
{
a[k][j]=a[k][j]/a[k][k];
}
b[k]=b[k]/a[k][k];
for(i=k+1;i<=n;i++)
{
for(j=k+1;j<=n;j++)
{
a[i][j]=a[i][j]-a[i][k]*a[k][j];
}
}
for(i=k+1;i<=n;i++)
{
b[i]=b[i]-a[i][k]*b[k];
}
}
for(i=n-1;i>=1;i--)
{
b[i]=b[i]-sum(n,i,j,a,b);
}
for(i=1;i<=n;i++)
{
printf("b[%d]=%f",i,b[i]);
printf("\n");
}
}
float selectmain(int k,int n,float a[][MAX],float b[])
{
int i,j,l;
float d,t;
d=a[k][k];
l=k;
for(i=k+1;i<n;i++)
{
if(fabs(a[i][k]>fabs(d)))
{
d=a[i][k];
l=i;
}
}
if(d==0)
{
printf("error");
exit(0);
}
while(l!=k)
{
for(j=k;j<=n;j++)
{
t=a[l][j];
a[l][j]=a[k][j];
t=a[k][j];
}
t=b[k];
b[k]=b[l];
t=b[l];
}
return a[k][k];
}
float sum(int n,int i,int j,float a[][MAX],float b[])
{
float s=0;
for(j=i+1;j<=n;j++)
{
s=s+a[i][j]*b[j];
}
return s;
}
#define MAX 20
float gauss(int n,float x[][MAX],float y[]);
float selectmain(int k,int n,float x[][MAX],float y[]);
float sum(int n,int i,int j,float x[][MAX],float y[]);
void main()
{
int i,j,n,end=1;
float a[MAX][MAX]={};
float b[MAX]={};
while(end==1)
{
printf("input n=");
scanf("%d",&n);
printf("input a[%d][%d]=",n,n);
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
scanf("%f",&a[i][j]);
}
}
printf("input b[%d]=",n);
for(i=1;i<=n;i++)
{
scanf("%f",&b[i]);
}
gauss(n,a,b);
printf("输入end的值(1代表继续输入/0代表结束)");
scanf("%d",&end);
}
exit(0);
}
float gauss(int n,float a[][MAX],float b[])
{
int i,j,k;
for(k=1;k<=n;k++)
{
selectmain(k,n,a,b);
for(j=k+1;j<=n;j++)
{
a[k][j]=a[k][j]/a[k][k];
}
b[k]=b[k]/a[k][k];
for(i=k+1;i<=n;i++)
{
for(j=k+1;j<=n;j++)
{
a[i][j]=a[i][j]-a[i][k]*a[k][j];
}
}
for(i=k+1;i<=n;i++)
{
b[i]=b[i]-a[i][k]*b[k];
}
}
for(i=n-1;i>=1;i--)
{
b[i]=b[i]-sum(n,i,j,a,b);
}
for(i=1;i<=n;i++)
{
printf("b[%d]=%f",i,b[i]);
printf("\n");
}
}
float selectmain(int k,int n,float a[][MAX],float b[])
{
int i,j,l;
float d,t;
d=a[k][k];
l=k;
for(i=k+1;i<n;i++)
{
if(fabs(a[i][k]>fabs(d)))
{
d=a[i][k];
l=i;
}
}
if(d==0)
{
printf("error");
exit(0);
}
while(l!=k)
{
for(j=k;j<=n;j++)
{
t=a[l][j];
a[l][j]=a[k][j];
t=a[k][j];
}
t=b[k];
b[k]=b[l];
t=b[l];
}
return a[k][k];
}
float sum(int n,int i,int j,float a[][MAX],float b[])
{
float s=0;
for(j=i+1;j<=n;j++)
{
s=s+a[i][j]*b[j];
}
return s;
}
展开全部
具体代码如下:
#include <iostream>
#include <cmath>
using namespace std;
int main()
{ double a,b,c,root1,root2;
cout<<"请输入一元二次方程的系数(a,b,c):"<<endl;
cin>>a>>b>>c;
if(a==0) //判断系数a是否为0
{ cout<<"不是一个一元二次方程"<<endl;
return -1;
}
double t =b*b-4*a*c;
if(t<0) //判断议程是否有实根
{ cout<<"方程没有实根"<<endl;
return -1;
}
if(t==0) //判断议程是否有等根
root1=root2=-b/(2*a);
else
{
root1=(-b+sqrt(t))/(2*a);
root2=(-b-sqrt(t))/(2*a);
}
cout<<"方程的根为:"<<root1<<"和"<<root2<<endl;
return 0;
}
#include <iostream>
#include <cmath>
using namespace std;
int main()
{ double a,b,c,root1,root2;
cout<<"请输入一元二次方程的系数(a,b,c):"<<endl;
cin>>a>>b>>c;
if(a==0) //判断系数a是否为0
{ cout<<"不是一个一元二次方程"<<endl;
return -1;
}
double t =b*b-4*a*c;
if(t<0) //判断议程是否有实根
{ cout<<"方程没有实根"<<endl;
return -1;
}
if(t==0) //判断议程是否有等根
root1=root2=-b/(2*a);
else
{
root1=(-b+sqrt(t))/(2*a);
root2=(-b-sqrt(t))/(2*a);
}
cout<<"方程的根为:"<<root1<<"和"<<root2<<endl;
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-08-30
展开全部
include <iostream>
include <cmath>
int main()
{
using namespace std;
float a,b,c,d,e,f;
cout<<"请输入二元一次方程组"<<endl<<"ax+by+c=0"<<endl<<"dx+ey+f=0"<<endl;
cout<<"a=";
cin>>a;
cout<<"b=";
cin>>b;
cout<<"c=";
cin>>c;
cout<<"d=";
cin>>d;
cout<<"e=";
cin>>e;
cout<<"f=";
cin>>f;
if(a*e==b*d)
{
cout<<"此方程无解"<<endl;
}
else
{
cout<<"x="<<(b*f-e*c)/(a*e-b*d)<<endl;
cout<<"y="<<(a*f-d*c)/(b*d-a*e)<<endl;
}
return 0;
}
include <cmath>
int main()
{
using namespace std;
float a,b,c,d,e,f;
cout<<"请输入二元一次方程组"<<endl<<"ax+by+c=0"<<endl<<"dx+ey+f=0"<<endl;
cout<<"a=";
cin>>a;
cout<<"b=";
cin>>b;
cout<<"c=";
cin>>c;
cout<<"d=";
cin>>d;
cout<<"e=";
cin>>e;
cout<<"f=";
cin>>f;
if(a*e==b*d)
{
cout<<"此方程无解"<<endl;
}
else
{
cout<<"x="<<(b*f-e*c)/(a*e-b*d)<<endl;
cout<<"y="<<(a*f-d*c)/(b*d-a*e)<<endl;
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-08-30
展开全部
全部用公式。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询