編程一元二次方程
1. c語言編寫一個求一元二次方程的實根的程序。
步驟:
打開visual C++ 6.0-文件-新建-文件-C++ Source File
2.
定義變數:
#include <stdio.h>
#include <math.h>
void main()
{
double a,b,c; /*定義系數變數*/
double x1,x2,p; /*定義根變數和表達式的變數值*/
2. C語言編程:求1元2次方程的根
#include <stdio.h>
#include <math.h>
int main()
{
double a,b,c; /*定義系數變數*/
double x1,x2,p; /*定義根變數和表達式的變數值*/
printf("請輸入a,b,c:"); /*提示用戶輸入三個系數*/
scanf("%lf%lf%lf",&a,&b,&c); /*接收用戶輸入的系數*/
printf(" "); /*輸出回行*/
p=b*b-4*a*c; /*給表達式賦值*/
x1=(-b+sqrt(p))/(2*a); /*根1的值*/
x2=(-b-sqrt(p))/(2*a); /*跟2的值*/
printf("x1=%f,x2=%f ",x1,x2); /*輸出兩個根的值*/
}
拓展資料
在實際的求法中,一般還需要判斷有無實根,這是可以通過p的值來判斷
3. c語言編寫一元2次方程。
程序想法沒錯,但設計的時候有點失誤。
void
main()
{
float
a=0,b=0,c=0,d=0,x1=0,x2=0,e=0;/*定義變數*/
printf("axe2+bx+c=0,(a,b,c):\n");/*提示輸入3個數*/
scanf("%f,%f,%f",&a,&b,&c);/*輸入的時候用float型
*/
e=sqrt(d);/*根號d
*/
x1=(-b+e)/(2*a);/*計算方程,公式有點不點,邏輯*/
x2=(-b-e)/(2*a);/*計算方程*/
printf("\n
positive:\n
x1=%f,\n
negative:\nx2=%f",x1,x2);/*輸出x1
x2,輸出的時候也要用float型*/
}
else
printf("equation");/*方程無解*/
getch();
}
//經修改,可以正常運行,
還有建議下,你就在定義變數的時候不要一大串一起定義類型,
有時候變數的類型是不無法隱型轉換的,就會出錯。
就像程序裡面的,開根號又不一定都開出個整數,大多都是帶小數的,就應該定義成float型,
最後的解也會直接化成帶小數的,要是你用long(長整型,也是整型的一種),
那小數點後面就將被程序自動省略,那問題可就大了,呵呵,。
還在做為printf輸出的時候,要給點提示,不然人家也不知道,這a,b,c是幹嘛用的。
4. 編程實現求一元二次方程的解。有圖看圖答題,謝謝各位大神!
代碼實現如下: 輸入的時候按照1 2 1類似的格式輸入,分別代表二次一次零次項的系數
#include <stdio.h>
#include <math.h>
void main()
{
float a,b,c,delt,x1,x2;
printf("輸入方程的三個系數:");
scanf("%f%f%f",&a,&b,&c);
delt = b*b-4*a*c;
if(delt>=0) {
x1 = (-b+sqrt(delt))/(2*a);
x2 = (-b-sqrt(delt))/(2*a);
printf("方程的解分別為:x1=%.2f x2=%.2f \n",x1,x2);
}
else {
printf("方程無實根\n");
}
return 0;
}
5. 編程編寫一個程序求一元二次方程的解
第二題:
#include<iostream.h>
void main()
{
int i,g,s,b;
for(i=100;i<1000;i++)
{
g=i%100;
b=i/100; //百位數
s=g/10; //十位數
g=g%10; //個位數
if(g*g+s*s+b*b==99)
cout<<i<<endl;
}
}
第三題:
#include <iostream>
using namespace std;
int main()
{
int i,j,maxi,maxj,mini,minj,max,min;
int a[2][3];
cout<<"請輸入6個整數作為矩陣元素"<<endl;
for(i=0;i<=1;i++)
{
for(j=0;j<=2;j++)
cin>>a[i][j];
};
maxi=maxj=mini=minj=0;
max=a[maxi][maxj];min=a[mini][minj];
for(i=0;i<=1;i++)
{
for(j=0;j<=2;j++)
if(max<a[i][j])
{
max=a[i][j];
maxi=i;maxj=j;
};
}
for(i=0;i<=1;i++)
{
for(j=0;j<=2;j++)
if(min>a[i][j])
{
min=a[i][j];
mini=i;minj=j;
}
}
cout<<"矩陣中最大值為"<<max<<"\n"<<"其位置位於a["<<maxi<<"]["<<maxj<<"]"<<endl;
cout<<"矩陣中最小值為"<<min<<"\n"<<"其位置位於a["<<mini<<"]["<<minj<<"]"<<endl;
return 0;
}
第四題:
#include<stdio.h>
viod main()
{
int sum=0,a[3][3];
printf("輸入數據:\n");
for(int i=0;i<3;i++)
for(int j=0;j<3;j++)
{
printf("a[%d][%d]=",i,j);
scanf("%d",&a[i][j]);
}
printf("\n");
for(int i=0;i<3;i++)
for(int j=0;j<3;j++)
sum+=a[i][j];
printf("%d\n",sum);
}
第五題:
#include <iostream> using namespace std; double a(int m) { double n=1; for (int i=1;i<=m;i++) n=n*i; return n; } int main() { int t; double y=1; for(t=1;(1.0/a(t))>=1e-6;t++) { if(t%2==0) y=y-(1.0/a(t)); else y=y+(1.0/a(t)); } cout<<"y=1+1/1!-1/2!+1/3!-1/4!+......="<<y<<endl; return 0; }
6. 怎樣用C語言編一個解一元二次方程的程序(可以看步驟)!
#include <stdio.h>
#include <math.h>
int main(void)
{
int a, b, c; //定義一元二次方程的三個數值;
printf("請依次輸入一元二次方程的三個參數a b c,中間以空格隔開\n");
scanf("%d %d %d", &a, &b, &c); //依次輸入一元二次方程的三個參數
double delta = b*b - 4*a*c; //定義delta的值為b*b - 4*a*c
double x1 = (-b + sqrt(delta))/(2 * a);
double x2 = (-b - sqrt(delta))/(2 * a);
if (delta>0) //delta大於0時,方程有兩個解
{
printf("一元二次方程有兩個解\n");
printf("一元二次方程的第一個解,x1 = %f\n",x1);
printf("一元二次方程的第二個解,x2 = %f\n",x2);
}
else if (delta ==0) //delta等於0,方程有兩個相同的解
{
printf("一元二次方程有兩個相同的解\n");
printf("一元二次方程的解為x1 = x2 =%f\n",x1);
}
else //delta小於0時,方程沒有解
{
printf("一元二次方程沒有解\n");
}
return 0;
}
7. c語言一元二次方程編程是怎麼樣的
c語言一元二次方程編程是#include<iostream> 。#include<cmath>。usingnamespacestd。intmain()。{floata,b,c;floatx1,x2; cin>a>>b>>c;floatdlt=b*b-4*a*c;if(dlt>=0){x1=-b/2/a+sqrt(dlt)。/2/ax2=-b/2/a-sqrt(dlt)/2/a。
形如x=p或(nx+m)=p(p≥0)的一元二次方程可採用直接開平方的方法解一元二次方程.如果方程化成x²=p的形式,那麼可得x=±p;(x²=p,x=±根號p)如果方程能化成(nx+m)=p(p≥0)的形式,那麼nx+m=±p。
簡潔的語言:
C語言包含的各種控制語句僅有9種,關鍵字也只有32個,程序的編寫要求不嚴格且以小寫字母為主,對許多不必要的部分進行了精簡。
實際上,語句構成與硬體有關聯的較少,且C語言本身不提供與硬體相關的輸入輸出、文件管理等功能,如需此類功能,需要通過配合編譯系統所支持的各類庫進行編程,故c語言擁有非常簡潔的編譯系統。
提供的控制語句具有結構化特徵,如for語句、if...else語句和switch語句等。可以用於實現函數的邏輯控制,方便麵向過程的程序設計。
8. 如何編程計算一元二次方程的根
#include"stdio.h"
#include"math.h"
main()
{
float a,b,c,d[8];
char x,y;
a=b=c=d[8]=0;
printf("請輸入a、b、c的值:\n");
scanf("%3f%3f%3f",&a,&b,&c);
d[0]=b*b-4*a*c;
printf("%.3f",d[0]);
if(a==0)
printf("該方程不是一元二次方程!!!");
else if(d[0]>0)
{
d[1]=(-b+sqrt(d[0]))/(2*a);
d[2]=(-b-sqrt(d[0]))/(2*a);
printf("該一元二次方程的解為:%.3f或%.3f\n",d[1],d[2]);
}
else if(d[0]==0)
{
d[3]=-b/(2*a);
printf("該一元二次方程的解為:%.3f\n",d[3]);
}
else
{
d[4]=-b/(2*a);
d[5]=sqrt(fabs(d[0]))/(2*a);
printf("該一元二次方程的解為:%.3f-%.3fi或%.3f-%.3fi\n",d[4],d[5],d[4],d[5]);
}
}
9. C語言編程 求一元二次方程的解
#include <stdio.h>
#include <math.h>/*用到數學函數時要把這個包含進來*/
int main(void)
{
int a,b,c;
double X,X1,X2;
printf("Input a:");
scanf("%d",&a); /*%f改成%d*/
printf("Input b:");
scanf("%d",&b); /*%f改成%d*/
printf("Input c:");
scanf("%d",&c); /*%f改成%d*/
if (a==0) /*=改成==*/
printf("該方程不是一元二次方程");
else if ((b*b-4*a*c)<0)
printf("該方程無解");
else if ((b*b-4*a*c)==0)/*應該是先判斷後計算*/
{
X=(double)(-b/(2*a));
printf("X= %lf",X);)/*double的格式輸出符對應是%lf*/
}
else if ((b*b-4*a*c)>0)
{
X1=(double)((-b+sqrt(b*b-4*a*c))/(2*a));
X2=(double)((-b-sqrt(b*b-4*a*c))/(2*a));
printf("X1=%lf, X2=%lf",X1,X2);
}
getch();
return 0;
}
10. C語言編程 解一元二次方程
M宏不需要開方,delta只是b*b-4*a*c,如果它大於等於0,再開方才有意義.變數也應該使用浮點數類型,修改如下:
//---------------------------------------------------------------------------
#include<stdio.h>
#include<math.h>
#define M (b*b-4*a*c) /*注意這里*/
main()
{double a,b,c,x1,x2; /*注意這里*/
printf("請輸入方程的三個系數:");
scanf("%lf,%lf,%lf",&a,&b,&c); /*注意這里*/
if (M>0)
{ x1=(-b+sqrt(M))/(2*a); /*注意這里*/
x2=(-b-sqrt(M))/(2*a); /*注意這里*/
printf("方程的兩個根是:\nx1=%lf,x2=%lf\n",x1,x2);/*注意這里*/
}
else if (M==0)
{ x1=-b/(2*a);
printf("方程具有兩個相等的實根:x1=x2=%lf\n",x1); /*注意這里*/
}
else
printf("輸入錯誤,請重新輸入\n");
}
//---------------------------------------------------------------------------