c语言编写一元一次函数 c语言编写一元一次函数ax+b =c无解输出no

C语言程序一元一次方程

因为a、b、x都是float类型,所有的scanf、printf里面都应该使用%f,不能使用%d,而且%和f之间不得有空格,而且scanf里面不要有其他字符,该语句应该为:

创新互联“设计定江山,服务赢天下“的思想,用细节和态度获得客户的认可与同行的尊重,服务是创新互联企业文化中重要的核心思想,每一位员工要致力成为客户心中坚实的服务后盾。

scanf("%f%f",a,b);

把这些修改了就基本上没有问题了,如果还有问题请补充,记住粘贴你修改后的程序和系统的提示,谢谢。

C语言编写一元一次函数ax+b=0

#include iostream

int main()

{

int a = 0,b = 0;

printf("请输入一次方程的系数a和b(以逗号隔开):");

scanf("%d,%d",a,b);

double c = (double)-b / a;

printf("一次方程 %dx+%d=0 的根是:x = %lf\n",a,b,c);

system("pause");

return 0;

解释C语言(逐句) 解一元一次方程的

#includestdio.h

#includestring.h

//前面两个是库函数,第一个用于输入输出,第二个用于调用对字符串的各种操作

//下面是main函数主体,定义为void类型则最后不需要return返回值,若定义为int则需要返回

void main()

{

char s[20], *p, b[10], ch; //定义了四个变量,S[20],b[10]是字符串数组,P是字符串指针,用

//于指向一个字符串,ch是字符变量

int i=0, f=0, f1=1; //定义int型的变量,变量作用下面会说明

int x=0, c=0;

int u=0;

gets(s); // gets()函数是库函数,用于从键盘接受你输入的一串东西,只接受你回车键以前

//的内容

p=s; //让指针p 指向 上面gets()函数接收到的那串字符,就是把那串字符的首地址给p

while(*++p!='\0'); //一个while循环,由于p只是指向那串字符的首地址,因此循环的作用是到达

//那串字符的末尾,'\0'表示一串字符串结束了,'\0'不是你输的,而是一串字

//符结束后,系统自动添上去的

*p=' '; *(p+1)='\0'; //上面while循环结束后p指针已经指向字符串的末尾了,现在把字符串的最

//后一位变为' '(空格),这时候需要自己给字符串末尾添加结束标志'\0',因

//为你把字符串单个执行系统不会自动给你添了

p=s; //上面p指针已经通过while循环跑到字符串末尾了,因此需要重新赋值下,

//这样p又一次指向字符串s的开头

//下面是解一元一次方程的过程,主体还是一个while循环

while(*p!='\0') //*p!='\0'是指只要p指针没指向字符串结束的位置,就一直循环

{

if(*p='0'*p='9') { b[i++]=*p; f=1; } //判断p此时指向的那个字符是否属于0-9的数字,

//如果是则把p指向的内容放在b数组

//否则执行else语句,并让f=1(f本来为0),注意

//i++使b数组递增

else

if(f==1) { //现在是else的部分,说明p指向的那个字符不是0-9了,而是其他字符

if(*p='a'*p='z') { //上面说到p指向的不是0-9,现在判断p是否指向a-z的26个字符,

//其实这样写是有问题的,万一你输入大写字母,结果会出错,建议改为 if(*p='a'*p='z'||*p='A'*p='Z')

ch=*p; //*p是指p指针指向的那个字符,注意p指向的是地址,*P代表p地址处存放

//的数据

//b数组中存放的是字符串中的数字部分,下面的if跟else分别是把char类型的数字转换为int型

//if是处理负数的情况,else处理正数的情况,如何判断正负数是通过,f1,u的值来看的

if((u==0f1==0)||(u==1f1==1)) {

b[i]='\0';

f=0; i=0; u=0;

x=x+ atoi(b)*(-1); //atoi()是库函数,把char类型的数据转换为int型

//x=x+ atoi(b)*(-1); 等效于 x+=atoi(b)*(-1);

} // end if((u==0f1==0)||(u==1f1==1))

else {

b[i]='\0';

f=0; i=0; u=0;

x+=atoi(b);

} //end else

} //end if(*p='a'*p='z')

//上面所有操作是在 if(*p='a'*p='z')内进行的,也就是遇到字母的时候,

//所以x最后的值存储的是变量(一元函数中的那个要求的值如2x=9中的x)的前缀

//(方程2x=9中2是叫前缀吗?)

//不对,那个2叫系数

else

if((u==0f1==0)||(u==1f1==1)) { b[i]='\0'; f=0; i=0; u=0; c+=atoi(b); }

else { b[i]='\0'; f=0; i=0;u=0; c=c+ atoi(b)*(-1);}

//上面两句是else中的内容,说明遇到的不是字母,因此c不是指系数,而是值,

//(比如2x=9中的9)

} //end if(f==1)

//到此判断p指向的那个字符的判断过程就结束了,但一次while循环没跑完,下面是指当遇到为负

//数的情况下,应该使u=1

//u=1就告诉我们遇到负数了,f1是指遇到=该怎么处理

if(*p=='-') u=1;

if(*p=='=') f1=0;

p++;

} //end while

//while循环到此结束,此时已经把一个一元方程化简了

//比如输入 2a+3a+6=12,可以认为他已经化简为 5a=6的形式

//而且系数5存放在变量x中,值6存放在c中,变量名字a存放在ch中

printf("%c=%d",ch,c/x); //输出结果

getch(); //可以不要,在windows平台下从控制台无回显地取一个字符

}

//最后告诉楼主一点,这样写太繁琐了,如果楼主用栈来实现,不可实现多元多次方程求解,而

//且就很简单的一个后缀式来处理

//不用这样各种if else来回判

//ps: 建文件的时候一定要写成c语言的**.c形式,不要写成c++的**.cpp格式,否则会报错

//因为atoi(),等函数在c++中的参数跟c中不一样,这样写会报错

问一道关于用C语言编程实现解一元一次方程的题。

思路:

方程组 定义为 方程的列表;

方程定义为 等式(= 连接的算式 你编程时,应该先找等号,把方程分成两半);

算式定义为 项的和(符号看成-1乘以某);

项定义为常数或者积;

积定义为常数乘以字母。(分清楚项以后,就可以移项,合并同类项。)

自顶向下分析。

理清楚变量和系数以后,用矩阵解。

c语言输入一个一元一次方程显示答案的程序

我这个程序只能接受ax+b=c这种形式的方程.

其中,a=1时可以省略,+b也可以省略.a,b,c不能为表达式,必须为确定的浮点数.

a不能为0

#include "stdio.h"

#include "stdlib.h"

void main()

{

float a,b,c;

int i,j;

char str[81];

gets(str);

for(i=0;str[i]!='\0';i++)

if(str[i]=='x' || str[i]=='X')

break;

if(str[i]=='\0') printf("error!\n");

if(i==0) a=1;

else a=atof(str);

if(a==0)

{

printf("a mustn't be zero!\n");

exit(1);

}

if(str[++i]=='=')

{

b=0;

c=atof(str+i+1);

}

else

{

if(str[i]=='+') i++;

for(j=i;str[j]!='\0';j++)

if(str[j]=='=') break;

b=atof(str+i);

c=atof(str+j+1);

}

printf("x=%f\n",(c-b)/a);

}

用c语言怎么解一元一次方程

用c语言怎么解一元一次方程:比如输入,3a+21=4a+1,输出:a=20。

#include

#include

#include

void

main()

{

\x09char

s[20],*p,b[10],ch;

\x09int

i=0,f=0,f1=1;

\x09int

x=0,c=0;

\x09int

u=0;

\x09gets(s);

\x09p=s;

while(*++p!='\0');

\x09*p='

';

*(p+1)='\0';

\x09p=s;

\x09while(*p!='\0')

\x09{\x09

\x09\x09if(*p='0'*p='a'*p


当前名称:c语言编写一元一次函数 c语言编写一元一次函数ax+b =c无解输出no
网站URL:http://pcwzsj.com/article/hehcgs.html