我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

c语言编程三角函数计算器 c#计算器三角函数

用C语言编写三角函数计算器,怎样写

首先输入要计算什么

创新互联主营开平网站建设的网络公司,主营网站建设方案,重庆APP开发公司,开平h5成都微信小程序搭建,开平网站营销推广欢迎开平等地区企业咨询

比如

sin

cos

...

然后输入要计算的值

接着调用对应的数学函数就可以了

sin

con

tan

cot这些都是有对应数学函数的

最后输出结果。

需要注意的是

C的数学三角函数都是弧度做参数

而不是角度。

如何用C语言编写一个科学计算器

用栈 就可以办到了。。。这个很详细的, lz 随便输入一个表达式,中间的计算过程全部输出了,lz试两个 就知道怎么回事了。 #include stdio.h

#include stdlib.h

#include string.h

#define MAXSIZE 4000;

typedef struct

{

char data[10];

int top;//头地址

int base;//基地址

int length;//长度

}Stack;

void init(Stack *st)//初始化栈

{

st-base=0;

st-top=0;

st-length=0;

}

int isEmpty(Stack *st)

{

int n=0,top,base;

top =st-top;

base =st-base;

if(top==base)

{

return 1;

}

return n;

}

int isFull(Stack *st)

{

int n=0,top,base;

top =st-top;

if(top=4000)

{

return 1;

}

return n;

}

char getTop(Stack *st)// 返回top值,不改变栈的结构

{

char n;

if(isEmpty(st))

{

printf("栈为空\n");

return 0;

}

int positon= st-top-1;

n= st-data[positon];//取出数据;

return n;

}

char pop(Stack *st)// 出栈,返回

{

char n;

if(isEmpty(st))

{

printf("栈为空\n");

return 0;

}

int positon= st-top-1;

n= st-data[positon];//取出数据;

st-top--;

st-length--;

st-data[positon]='\0';//消除数据

return n;

}

void push(char n,Stack *st)//入栈

{

int positon ;

if(isFull(st))

{

printf("栈满\n");

}

else

{

positon= st-top;//获取位置

st-data[positon]=n;//存入数据

st-top++;//改变位置

}

}

void show(Stack *m1)//输出栈中的数据

{

int top,base;

top=m1-top;

base=m1-base;

while(topbase)

{

printf("%c,",m1-data[--top]);

}

printf("\n");

}

int isOperate(char temp)//是否是操作符

{

if(temp=='+'||temp=='-'||temp=='*'||temp=='/'||temp=='('||temp==')'||temp=='#')

{

return 1;

}

return 0;

}

int isValue(char temp)//是否是数值

{

if(temp='0'temp='9')//

{

return 1;

}

else

{

return 0;

}

}

int isAvail(char temp)//是否有效字符

{

if(isOperate(temp)||isValue(temp))//如果temp既不是操作符和数值的话,则它是非法的

{

return 1;

}

return 0;

}

int detect(char temp)//搜索矩阵位置

{

int i=0;

char oper[7]={'+','-','*','/','(',')','#'};

for(i=0;i7;i++)

{

if(temp==oper[i])

{

return i;

}

}

}

char Priority(char temp,char optr)//判断优先级

{

/**//*

+ - * / ( ) #

1 2 3 4 5 6 7

+ 1

- 2

* 3

/ 4

( 5 = 0

) 6 = 0

# 7 0 =

*/

int row ,col;

char priority[7][7]={/**//* + - * / ( ) # */

{'','','','','','',''},

{'','','','','','',''},

{'','','','','','',''},

{'','','','','','',''},

{'','','','','','=',''},

{'','','','','=','0',''},

{'','','','','','','='},

};

row = detect(temp);//找出对应的矩阵下标;

col = detect(optr);

// printf("%d,%d",row,col);

//优先级存储在一个7x7的矩阵中,对应关系上图;

return priority[row][col];

}

char evaluate(int a,int b,char oper)

{

switch(oper)

{

case '+': return a+b+'0';

case '-': return a-b+'0';

case '*': return a*b+'0';

case '/': return a/b+'0';

default : return 0+'0';

}

}

int calculateExpress(char *express)//计算表达式

{

int result=0;

int a,b;

// char oper,result;

Stack OPTR,OPND;//OPTR存储操作符,OPND操作数值

init(OPTR);

init(OPND);

push('#',OPTR);//默认第一个位'#'

////////////////////-算法-////////////////////////////

while(*express!='\0')

{

char temp;

temp= *(express);

printf("---------------------------------\n");

printf("当前的符号为%c\n",temp);

if(isAvail(temp))//是否是有效字符

{

if(isOperate(temp) )//输入的是操作符

{

char oper,result;

char optr = getTop(OPTR);//栈中top位的操作符

printf("栈顶操作符位:%c\n",optr);

char prior = Priority(temp,optr);//判断优先级

switch(prior)

{

case '':

push(temp,OPTR);

printf("将符号位%c入栈\n",temp);

express++;

break;

case '':

//int a,b;

//char oper,result;

a=pop(OPND)-'0';//存在栈中的都是char字符

b=pop(OPND)-'0';

oper=pop(OPTR);

result=evaluate(b,a,oper);//出栈一个操作符,计算结果

//printf("%d",result-'0');

push(result,OPND);//结果入OPND

printf("%d%c%d结果为:%d\n",b,oper,a,result-'0');

break;

case '=':

//消除括号

pop(OPTR);

printf("消除括号\n");

express++;

break;

}

}

if(isValue(temp))//输入的是数值

{

push(temp,OPND);//将数值位入栈;

express++;

printf("将数值%c压入栈\n",temp);

//show(OPND);

}

}

else //表达式中有非法字符

{

printf("表达式中有非法字符\n");

exit(-1);//退出程序

}

}

// show(OPND);

// show(OPTR);

return getTop(OPND)-'0';

}

void inputExpress(char *express)//输入表达式

{

int length=0;

printf("请输入一个表达式:");

scanf("%s",express);

int len =strlen(express);

express[len]='#';//表达式最后一位默认为'#';

express[len+1]='\0';

}

void output(char *express,int result)//输出表达式

{

int i=0;

printf("----------------------------------------\n表达式:");

while(express[i]!='#')

{

printf("%c",express[i]);

i++;

}

printf("=%d\n",result);

}

int main()

{

char express[100];//表达式

int result =0;

inputExpress(express);//输入表达式

result = calculateExpress(express);//计算表达式;

output(express,result); //输出表达式

//、、、、、、、、、、、、、测试优先级。

/**//*

char m='7' ;

m=Priority('+','*');

printf("优先级为%c",m);

int m=evaluate(5,6,'m');

printf("%d",m);

*/

return 0;

}

紧急求助啊c语言计算器实现加减乘除混合运算及三角函数计算以及对数阶乘计算。

#includestdio.h

#includewindows.h

#includemath.h

double EPS=10E-6;

double sum(double a,double b)

{

return a+b;

}

double sub(double a,double b)

{

return a-b;

}

double mul(double a,double b)

{

return a*b;

}

double divv(double a,double b)

{

return a/b;

}

int rem(int a , int b)

{

return a%b;

}

int addnumber(int c,int d)

{

int sum=0;

for(int i=c;i=d;i++)

{

sum+=i;

}

return sum;

}

int factor(int n)

{

int f=1;

for(int i=1;i=n;i++)

{

f*=i;

}

return f;

}

void displaymenu()

{

printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ \n");

printf("*############高级计算器############* \n");

printf("************************************ \n");

printf("* ①加法运算 * \n");

printf("* ②减法运算 * \n");

printf("* ③乘法运算 * \n");

printf("* ④除法运算 * \n");

printf("* ⑤取余运算 * \n");

printf("* ⑥累加运算 * \n");

printf("* ⑦阶乘运算 * \n");

printf("* ⊙结束运算 * \n");

printf("************************************ \n");

printf("************************************ \n");

}

void main()

{

int c,d; /*用于做四则运算的两个数值的说明*/

double a,b; /*用来做累加函数的两个参数值的说明*/

int intresult;

double result; /*用于保存表单运算中函数的返回值*/

int choice;

displaymenu();/*保存用户选择项目菜单项*/

while(1)

{

printf("请选择你所进行运算项目的符号:");

scanf("%d",choice);

switch(choice)

{

case 1: /*加法计算*/

printf("请输入两个数字:");

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

result=sum(a,b);

printf("%lf+%lf的计算结果是:%lf\n",a,b,result);

break;

case 2: /*减法计算*/

printf("请输入两个数字:");

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

result=sub(a,b);

printf("%lf-%lf的计算结果是:%lf\n",a,b,result);

break;

case 3: /*乘法计算*/

printf("请输入两个数字:");

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

result=mul(a,b);

printf("%lf*%lf的计算结果是:%lf\n",a,b,result);

break;

case 4: /*除法计算*/

{

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

if(b-0.0EPS) printf("数字错误\n");

else

{

printf("请输入两个数字:");

result=divv(a,b);

printf("%lf/%lf的计算结果是:%lf\n",a,b,result);

}

break;

}

case 5: /*取余计算*/

printf("请输入两个数字:");

scanf("%d%d",c,d);

result=rem(c,d);

printf("%d % %d的计算结果是:%d\n",c,d,result);

break;

case 6: /*累加计算*/

printf("请输入两个整数");

scanf("%d%d",c,d);

intresult=addnumber(c,d);

printf("%d-%d的累加计算结果是:%d\n",c,d,intresult);

break;

case 7: //阶乘计算

{

printf("请输入一个大于0小于10的整数字");

scanf("%d",c);

if(c0||c10)

{

printf("请输入一个大于0小于10的整数字,数据错误。\n");

break;

}

intresult=factor(c);

printf("%d的阶乘计算结果是:%d\n",c,intresult);

break;

}

case 0:

printf("谢谢使用。欢迎下次再用。\n");

return ;

default:

printf("选择错误,程序结束\n");

break;

}

}

}

三角函数直接用库函数

#include "math.h"

#include "stdio.h"

void main()

{

char a = ' ';

double i;

printf("请输入要计算的函数类型!例如:s(arcsin),c(arccosine),t(arctangent)\n");

scanf("%c",a);

printf("请输入要计算的值!\n");

scanf("%lf",i);

switch(a)

{

case 's':printf("%lf",asin(i));break;

case 'c':printf("%lf",acos(i));break;

case 't':printf("%lf",atan(i));break;

}

}

c语言计算器怎样做三角函数功能?

很简单的,比如你已经有一个表达式char exp[];

那么 char * s = strstr(exp, "sin");

if(s) {

执行sin(alpha)

}

就可以了

strstr是一个字符串函数,用于查找字符串内与关键字匹配的那个位置

比如char exp[] = "cos(a) + sin(b) - tan(c)";

那么char * s = strstr(exp, "sin");

printf(s)的结果是:

sin(b) - tan(c)

求一个计算三角函数的C语言程序(不要使用C库,要自己定义函数)

#include

#include

int main()

{

double n; //sin cos是函数,不能定义成变量

scanf("%lf",n);

n=sin(n); //求n的sin()值,并返回给n

printf("%lf\n",n);//输出n

return 0;

}

如何用C语言实现三角函数的计算

包含头文件math.h后,所有三角函数的库函数就都可以直接引用了。比如求x的正弦就用sin(x),它返回一个double值。注意x以弧度计……


分享名称:c语言编程三角函数计算器 c#计算器三角函数
网址分享:http://shouzuofang.com/article/dosogsp.html

其他资讯