鱼C论坛

 找回密码
 立即注册
查看: 2368|回复: 1

[技术交流] 四则运算

[复制链接]
发表于 2015-8-9 21:59:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
今天开始学习栈了了解了下什么叫做栈说就是一种特殊点的线性表什么什么的,大概有点了解了然后书上介绍了四则运算的方法,先把输入的四则运算改成后缀式,最后计算。具体算法大家自己百度把,看起来好像不是很难于是乎我开始动手写了,按照自己的想法写完之后开心的按下了Ctrl+ F5 结果一堆BUG和error 弄了三个小时终于是实现功能了,当然还是很不完善,大牛勿喷。
  1. #include<stdio.h>//9+(3-1)*3+10/2
  2. #include<windows.h>
  3. //#include<string.h>

  4. int main()
  5. {
  6.         char str[100] = { '\n' };
  7.         char temp[100] = { '\n' };
  8.         char ch,t;
  9.         int calc[50];
  10.         int i = 0, j = 0, k, l = 0;
  11.         t = '\n';
  12.         printf("请输入一个四则混合运算:");
  13.         //开始处理原式
  14.         while ((ch = getchar()) != '\n')//一个一个的读取输入的字符
  15.         {
  16.                 if (ch == '(')//如果是'('直接压栈
  17.                 {
  18.                         temp[i] = ch;
  19.                         i++;
  20.                 }
  21.                 else if(ch == ')')//如果是')'就把栈顶元素输出到后缀表达式存放数组str 直到栈顶元素为'('
  22.                 {
  23.                         while (temp[i-1]!='(')
  24.                         {
  25.                                 if (i == 0)//')'个数多于'('
  26.                                 {
  27.                                         printf("括号不匹配!\n");
  28.                                         system("pause");
  29.                                         return 0;
  30.                                 }
  31.                                 str[j] = ' ';//数字数字符号符号直接全部加上空格为了防止123不知道是1 2 3 还是12 3 这种情况
  32.                                 j++;
  33.                                 str[j] = temp[i - 1]; //把栈顶元素输出到后缀表达式存放数组str
  34.                                 i--;
  35.                                 j++;
  36.                         }
  37.                         i--;
  38.                 }
  39.                 else if(ch == '*' || ch == '/')//如果是'*' 或者 '/'
  40.                 {
  41.                         if (!(t == '+' || t == '-' || t == '*' || t == '/')) //判断是否连续输入符号 如5 ++ 6
  42.                         {
  43.                                 str[j] = ' ';
  44.                                 j++;
  45.                                 while (temp[i - 1] == '*' || temp[i - 1] == '/') //只要优先级没有比栈顶的高就出栈直到优先级高于栈顶的或者栈顶为'('
  46.                                 {
  47.                                         str[j] = ' ';
  48.                                         j++;
  49.                                         str[j] = temp[i - 1];
  50.                                         i--;
  51.                                         j++;
  52.                                 }
  53.                                 temp[i] = ch;//最后再压栈
  54.                                 i++;
  55.                         }
  56.                         else
  57.                         {
  58.                                 printf("不能连续输入运算符号!\n!");
  59.                                 system("pause");
  60.                                 return 0;
  61.                         }
  62.                 }
  63.                 else if(ch == '+' || ch == '-')//如果是'+' 或者 '-'
  64.                 {
  65.                         str[j] = ' ';
  66.                         j++;
  67.                         if (!(t == '+' || t == '-' || t == '*' || t == '/'))
  68.                         {
  69.                                 while (temp[i - 1] != '(' && i>0) //优先级最低了所以除非栈顶是'('否则全部出栈
  70.                                 {
  71.                                         str[j] = ' ';
  72.                                         j++;
  73.                                         str[j] = temp[i - 1];
  74.                                         i--;
  75.                                         j++;
  76.                                 }
  77.                                 temp[i] = ch;
  78.                                 i++;
  79.                         }
  80.                         else
  81.                         {
  82.                                 printf("不能连续输入运算符号!\n!");
  83.                                 system("pause");
  84.                                 return 0;
  85.                         }
  86.                 }
  87.                 else if (ch >= '0' && ch <= '9') // 如果是数字直接输出到后缀表达式存放数组str
  88.                 {
  89.                         str[j] = ch;
  90.                         j++;
  91.                 }
  92.                 else
  93.                 {
  94.                         printf("存在非法字符!\n");
  95.                         system("pause");
  96.                         return 0;
  97.                 }
  98.                 t = ch;
  99.         }

  100.         while (i>0)
  101.         {
  102.                 if (temp[i - 1] != '(')//把栈中的全部输出到后缀表达式存放数组str
  103.                 {
  104.                         str[j] = ' ';
  105.                         j++;
  106.                         str[j] = temp[i - 1];
  107.                         i--;
  108.                         j++;
  109.                 }
  110.                 else//'('个数多
  111.                 {
  112.                         printf("括号不匹配!\n");
  113.                         system("pause");
  114.                         return 0;
  115.                 }
  116.         }
  117.         k = 0;
  118.         /*
  119.         for (i = 0; i < j; i++)
  120.         {
  121.                 printf("%c",str[i]);
  122.         }
  123.         */
  124.         for (i = 0; i < j; i++) // 还要对后缀表达式进行处理把  '3''8' 变成 38 储存以用于计算
  125.         {
  126.                 if (str[i] >= '0' && str[i] <= '9') //如果是数字
  127.                 {
  128.                         if (str[i + 1] != ' ') //判断下一个是不是空格
  129.                         {
  130.                                 k = k * 10 + (str[i] - 48);//如果不是说明类似于123 是123 不是1 2 3 现在读取的1还不是结果 进行计算
  131.                         }
  132.                         else//如果是空格
  133.                         {
  134.                                 if (k == 0)//判断是不是一位数(数字是就是0哪边都可以)
  135.                                 {
  136.                                         calc[l] = str[i] - 48;//是一位数就直接保存当前数字
  137.                                 }
  138.                                 else
  139.                                 {
  140.                                         k = k * 10 + (str[i] - 48);//不是进行最后一次运算得到结果在保存 并初始化K
  141.                                         calc[l] = k;
  142.                                         k = 0;
  143.                                 }
  144.                                 l++;
  145.                                
  146.                                 while (str[i + 1] == ' ')//清理空格
  147.                                 {
  148.                                         i++;
  149.                                 }
  150.                         }
  151.                 }
  152.                 //至此对原式的处理全部完毕
  153.                 //开始计算 算法自己百度
  154.                 else if (str[i] == '+')
  155.                 {
  156.                         l = l - 1;
  157.                         calc[l-1] = calc[l-1] + calc[l ];
  158.                 }
  159.                 else if(str[i] == '-')
  160.                 {
  161.                         l = l - 1;
  162.                         calc[l-1] = calc[l-1] - calc[l];
  163.                 }
  164.                 else if (str[i] == '*')
  165.                 {
  166.                         l = l - 1;
  167.                         calc[l-1] = calc[l-1] * calc[l];
  168.                 }
  169.                 else if (str[i] == '/')
  170.                 {
  171.                         l = l - 1;
  172.                         calc[l-1] = calc[l-1] / calc[l];
  173.                 }
  174.                 else
  175.                 {
  176.                         while (str[i + 1] == ' ')
  177.                         {
  178.                                 i++;
  179.                         }
  180.                 }
  181.         }
  182.         printf("结果是:%d\n", calc[l-1]);
  183.         system("pause");

  184.         return 0;
  185. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-4-28 09:41:32 | 显示全部楼层
C++里面有专门讲这个的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-27 03:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表