C语言参考程序—无符号一位整数的四则运算

简介:

题目:输入一个无符号的一位整数的四则运算表达式,输出其结果。例如输入:1+3*6-2,则输出:17

分析:因为不涉及到括号,只是简单的四则运算,我的想法是如果有乘除法先计算,没有的话就按照加减法从左到右的顺序进行计算。在开始的时候,首先检查是否有乘除法运算符,有的话就取出前后两个操作数进行计算,将结果保存起来。没有的话就将加减运算符先存起来。

主要过程:

1、输入的是一个四则运算的表达式,在计算机中按照字符串的形式存储。数据和运算符需要分开处理。

2、引入一个整型的数组,其大小为字符串长度加一,加一是为了方便整型数组判断结束。

3、对表达式字符串循环进行字符判断,如果是数字,则将数组存入引入的整型数组,如果不是则分两种情况:(1)是乘法或者是除法运算符,那就将整型数组中当前的最新数据取出,将表达式字符串当前位置的下一个位置的数字取出,进行乘法计算,将计算所得的存放到整型数组当前位置。(即覆盖掉第一个操作数的位置)。(2)是加法或者是减法,分数组和运算符分别存入到整型数组中。

4、第3步完成以后,整型数组中存放的只是关于加减法运算的表达式。此时就可以从到右进行运算。取出操作符,通过操作符的位置取出两个操作数,保证每次计算后的结果存放到整型数组的第一个位置处。整个计算结果后,整型数组第一个位置是最终的计算结果。

完整的C语言程序如下所示:

复制代码
 1 #include <stdio.h>
 2 #include <string.h>
 3 #include <stdlib.h>
 4 #define LEN 100  //假设表达式的最大长度为100
 5 //计算表达式的函数声明
 6 int caculate(char* exp);
 7 int main()
 8 {
 9  //表达式字符串
10  char *expression = (char*)malloc(sizeof(char)*LEN);
11  while(1)
12  {
13   printf("Enter an expression: ");
14   scanf("%s",expression);
15   printf("The result is: %d\n",caculate(expression));
16  }
17  //释放内存空间
18  free(expression);
19  return 0;
20 }
21 int caculate(char* exp)
22 {
23  char* p = exp;
24  int result = 0;
25  //动态分配,引入一个数组
26  int* datas = (int*)malloc(sizeof(int)*(strlen(exp)+1));
27  int* pNext = datas;
28  int* pCur = NULL;
29  int* pTemp = NULL;
30  int m,n;
31  //先计算乘除法
32  while(*p!='\0')
33  {
34   if(*p == '*' || *p == '/')
35   {
36    //在datas中取第一个操作数
37    m = *pCur;
38    //在字符串中取第二个操作数
39    n = *(p+1) ^ 0x30;
40    if(*p == '*')
41     //进行乘法运算,结果覆盖当前的值
42     *pCur = m*n;
43    else
44     //进行除法运算,结果覆盖当前的值
45     *pCur = m/n;
46    p++;
47   }
48   else
49   {
50    //如果是数字,将字符转换为数字
51    *pNext = (*p>='0' && *p <='9') ?  *p ^ 0x30 : *p ;
52    pCur = pNext;  //指向当前
53    pNext++;  //指向下一个
54   }
55   p++;
56  }
57  //此时只做加减法,每次将计算的结果保存在datas的第一个位置处
58  for( pTemp=datas;pTemp!=pNext;++pTemp)
59     {
60   if(*pTemp =='+' || *pTemp == '-')  
61   {
62    //第一个操作数始终放在datas的第一个位置
63    m = *datas; 
64    //取第二个操作数
65    n = *(pTemp+1);
66    if(*pTemp == '+')
67     *datas = m+n;
68    else
69     *datas = m-n;
70    pTemp++;
71   }
72  }
73  //最终的计算结果保存在datas的第一个位置
74  result = *datas;
75  //释放内存空间
76  free(datas);
77  return result;
78 }
复制代码

程序测试结果如下:

相关文章
|
1月前
|
C语言
最简单的C语言程序示例
最简单的C语言程序示例
20 0
|
1月前
|
Serverless C语言
C语言程序通常具有以下基本结构
C语言程序通常具有以下基本结构
10 0
|
1月前
|
C语言 C++
第一个c语言程序
第一个c语言程序
|
1月前
|
程序员 编译器 C语言
C语言的程序常量
C语言的程序常量
10 0
|
16天前
|
存储 编译器 C语言
深入探索C语言动态内存分配:释放你的程序潜力
深入探索C语言动态内存分配:释放你的程序潜力
28 0
|
1月前
|
C语言
C语言最基本程序控制结构
C语言最基本程序控制结构
14 0
|
1月前
|
存储 Serverless C语言
C语言程序的结构
C语言是一种广泛使用的编程语言,其程序结构清晰,易于理解。下面我们将详细探讨C语言程序的基本结构,并通过一个示例代码来展示这些组成部分是如何协同工作的。 一、C语言程序的基本结构
14 0
|
1月前
|
程序员 C语言
最简单的C语言程序举例
C语言是一种广泛使用的计算机编程语言,适合用于系统编程,也可以用于编写应用程序。它的语法清晰明了,功能强大,是很多程序员的首选语言。下面,我们将通过一个最简单的C语言程序来介绍其基本结构和语法。
26 0
|
1月前
|
前端开发 Unix Linux
Linux indent命令 (格式化C语言源代码的程序)
Linux indent命令 (格式化C语言源代码的程序)
18 0
Linux indent命令 (格式化C语言源代码的程序)
|
1月前
|
存储 编译器 C语言