首页 > 其他分享 >C语言:计算器

C语言:计算器

时间:2022-11-18 12:34:06浏览次数:55  
标签:return int double t2 t1 fuc 计算器 C语言

题目

请你编写一个科学计算器,支持多括号嵌套的四则运算,三角函数及指数对数运算功能可选(功能越多越好,指数的输入格式为 a^b,对数的输入格式为 loga b,(其中a为底数))


代码


#include<stdio.h>
#include<math.h>


typedef struct {
    int flg[100];
    double num[100];
    int topNum;
    int topFlg;
    int sumFlg;
}stack;

int isNumFull(stack *s){
    if(s->topNum == 100)
        return 1;
    return 0;
}

int isFlgFull(stack *s){
    if(s->topFlg == 100)
        return 1;
    return 0;
}

int isNumEmpty(stack *s){
    if(s->topNum == 0)
        return 1;
    return 0;
}

int isFlgEmpty(stack *s){
    if(s->topFlg == 0)
        return 1;
    return 0;
}

double popNum(stack *s){
    if(isNumEmpty(s))
        return -114514;

    s->topNum = (s->topNum) - 1;
    return s->num[(s->topNum)];
}

int popFlg(stack *s){
    if(isFlgEmpty(s))
        return '0';

    s->topFlg = (s->topFlg) - 1;
    if(s->flg[(s->topFlg)] != '('){
        s->sumFlg--;
    }
    return s->flg[(s->topFlg)];
}

int pushNum(stack *s,double *a){
    if(isNumFull(s))
        return 0;

    s->num[(s->topNum)] = *a;
    s->topNum = (s->topNum) + 1;
    *a = 0;
    return 1;
}

int pushFlg(stack *s,int a){
    if(isFlgFull(s))
        return 0;

    s->flg[(s->topFlg)] = a;
    s->topFlg = (s->topFlg) + 1;
    if(a != '('){
        s->sumFlg++;
    }
    return 1;
}

double function1(double a1,double a2,int flg){
    switch(flg){
        case '+':
            return a1 + a2;
        case '-':
            return a1 - a2;
        case '*':
            return a1 * a2;
        case '/':
            return a1 / a2;
        case '^':
            return pow(a1,a2);
    }
    return 0;
}

double function2(double a, int fuc){
    a = a / 180 * 3.1415926535;
    switch(fuc){
        case 330:	//sin
            return sin(a);
        case 325:	//cos
            return cos(a);
        case 323:	//tan
            return sin(a) / cos(a);
        case 315:	//sec
            return 1 / cos(a);
        case 313:	//csc
            return 1 / sin(a);
        case 326:	//cot
            return cos(a) / sin(a);
    }
    return 0;
}

double function3(double a1,double a2){
    return log(a2) / log(a1);
}

double getNum(double *lf){
    return scanf("%lf",lf);
}

int main() {
    char inp[1],tmp[1];
    double t1 = 0;
    double t2 = 0;
    int fuc,i;
    stack s, *p;
    s.topFlg = 0;
    s.topNum = 0;
    s.sumFlg = 0;
    p = &s;

    if ((inp[0] = getchar()) == '-') {
        getNum(&t1);
        t1 = 0 - t1;
        pushNum(p, &t1);
    }
    else{
        goto label1;
    }

    while (1) {
        inp[0] = getchar();
        label1:

        if (inp[0] >= '0' && inp[0] <= '9') {
            t1 = t1 * 10 + inp[0] - '0';
            continue;
        }
        if(inp[0] == '.'){
            getNum(&t2);
            for(;t2>1;t2 /= 10);
            t1 = t1 + t2;
            t2 = 0;
        }

        if (t1 != 0)
            pushNum(p, &t1);

        if(inp[0] == '\n' || inp[0] == EOF ){
            break;
        }

        if (inp[0] >= 'a' && inp[0] <= 'z') {
            fuc = inp[0];
            fuc += getchar();
            fuc += getchar();
            getNum(&t1);
            if(fuc == 322){
                getchar();
                getNum(&t2);
                t1 = function3(t1,t2);
            }
            else {
                t1 = function2(t1, fuc);
            }
            pushNum(p, &t1);
            continue;
        }

        if (inp[0] == '+' || inp[0] == '(') {
            pushFlg(p, inp[0]);
            continue;
        }

        if (inp[0] == '-'){
            if (getNum(&t1) == 0){
                pushFlg(p, inp[0]);
            } else {
                t1 = -t1;
                pushNum(p, &t1);
                if(p->sumFlg == p->topNum -2){
                    pushFlg(p, '+');
                }
            }

        }

        if (inp[0] == '*' || inp[0] == '/' || inp[0] == '^') {
            tmp[0] = inp[0];
            if(0 == getNum(&t2)){       //为括号或者是负号
                fuc = getchar();
                if(fuc == '('){
                    pushFlg(p, inp[0]);
                    pushFlg(p, '(');
                    continue;
                } else if (fuc == '+' || fuc == '-' || fuc == '*' || fuc == '/' || fuc == '^'){
                    getNum(&t2);
                    t2 = -t2;
                } else {
                    fuc += getchar();
                    fuc += getchar();
                    getNum(&t1);
                    if(fuc == 322){
                        getchar();
                        getNum(&t2);
                        t1 = function3(t1,t2);
                    }
                    else {
                        t1 = function2(t1, fuc);
                    }
                    t2 = t1;
                 }
            }
            t1 = popNum(p);
            t1 = function1(t1, t2, tmp[0]);
            pushNum(p, &t1);
            continue;
        }

        if (inp[0] == ')') {
            while ((fuc = popFlg(p)) != '(') {
                t2 = popNum(p);
                t1 = popNum(p);
                t1 = function1(t1, t2, fuc);
                pushNum(p, &t1);
            }
            continue;
        }
    }

    while (p->topNum != 1) {
        fuc = popFlg(p);
        t2 = popNum(p);
        t1 = popNum(p);
        i = fuc;
        fuc = popFlg(p);
        if(fuc == '-') {
            t1 = 0 - t1;
            fuc = '+';
        }
        pushFlg(p,fuc);
        t1 = function1(t1, t2, i);
        pushNum(p, &t1);
    }

    printf("%lf",p->num[0]);

    return 0;
}

标签:return,int,double,t2,t1,fuc,计算器,C语言
From: https://www.cnblogs.com/Shin404/p/16902806.html

相关文章

  • C语言:约瑟夫环
    题目n个人围成一圈,从第一个人开始报数,数到m的人出列,再由下一个人重新从1开始报数,数到m的人再出圈,依次类推,直到所有的人都出圈,请输出依次出圈人的编号。 例如:  ......
  • C语言:IPv6地址压缩
    题目IPv6二进位制下为128位长度,以16位为一组,每组以冒号“:”隔开,可以分为8组,每组以4位十六进制方式表示。例如:2001:0db8:0000:0000:0123:4567:89ab:cdef是一个......
  • C语言:大数减法
    题目输入两个正整数(20位以上),计算两个数的差 例如:  输入:5626255555855853666554212125121252222521  输出:2050430437306314144代码#include<stdio.h>#inclu......
  • C语言:最小子数组和
    题目给你一个整数数组,请你找出一个具有最小和的连续子数组(子数组最少包含一个元素),返回其最小和。子数组是数组中的一个连续部分。 例如:  输入:-21-34-1-21-......
  • C语言:蛇形方阵
    题目给出一个不大于9的正整数n,输出n×n的蛇形方阵。从右上角填上1开始,逆时针方向依次填入数字,如同样例所示。注意每个数字都右对齐,中间用空格隔开。 例如:  ......
  • C语言:连续子串
    题目输入一个字符串,输出其所有的子串(不包含本身,输出每个子串间有空格)。子串:对于一个字符串变量,例如"adereegfbw",它的子串就是像"ader"这样可以从中找到的连续的字符......
  • C语言:规则排序
    题目输入正整数n,再输入n个正整数,先将其中的奇数从小到大排序,再将偶数从大到小排序。 例如:  输入:828522391125  输出:35911252282代码#in......
  • C语言:亲密数对
    题目输入N,N在2至3000之间,求2至N中的亲密数对。所谓亲密数对,就是A的因子和等于B,B的因子和等于A,且A≠B。如48和75是亲密数对。48的因子和为2+3+4+6......
  • C语言:学号输出
    题目用输出你的学号对应的八位数(每位数大小为55,每个数之间距离三个空格) 例如  输入12345678 输出: 代码#include<stdio.h>intmain(){charinp......
  • C语言:一元二次方程求解
    题目已知一元二次方程......