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 }
复制代码

程序测试结果如下:

相关文章
|
3月前
|
存储 自然语言处理 编译器
【C语言】编译与链接:深入理解程序构建过程
【C语言】编译与链接:深入理解程序构建过程
|
5月前
|
存储 算法 C语言
"揭秘C语言中的王者之树——红黑树:一场数据结构与算法的华丽舞蹈,让你的程序效率飙升,直击性能巅峰!"
【8月更文挑战第20天】红黑树是自平衡二叉查找树,通过旋转和重着色保持平衡,确保高效执行插入、删除和查找操作,时间复杂度为O(log n)。本文介绍红黑树的基本属性、存储结构及其C语言实现。红黑树遵循五项基本规则以保持平衡状态。在C语言中,节点包含数据、颜色、父节点和子节点指针。文章提供了一个示例代码框架,用于创建节点、插入节点并执行必要的修复操作以维护红黑树的特性。
117 1
|
5月前
|
NoSQL 编译器 程序员
【C语言】揭秘GCC:从平凡到卓越的编译艺术,一场代码与效率的激情碰撞,探索那些不为人知的秘密武器,让你的程序瞬间提速百倍!
【8月更文挑战第20天】GCC,GNU Compiler Collection,是GNU项目中的开源编译器集合,支持C、C++等多种语言。作为C语言程序员的重要工具,GCC具备跨平台性、高度可配置性及丰富的优化选项等特点。通过简单示例,如编译“Hello, GCC!”程序 (`gcc -o hello hello.c`),展示了GCC的基础用法及不同优化级别(`-O0`, `-O1`, `-O3`)对性能的影响。GCC还支持生成调试信息(`-g`),便于使用GDB等工具进行调试。尽管有如Microsoft Visual C++、Clang等竞品,GCC仍因其灵活性和强大的功能被广泛采用。
158 1
|
1月前
|
C语言
【C语言】符号优先级详解 -《谁与争锋 ! 》
理解C语言中的运算符优先级和结合性是编写正确代码的关键。本文详细介绍了C语言中的各种运算符、它们的优先级和结合性,并通过示例展示了如何正确使用这些运算符。掌握这些知识,将有助于编写出逻辑严谨、结构清晰的C语言程序。
82 8
|
5月前
|
编译器 C语言 计算机视觉
C语言实现的图像处理程序
C语言实现的图像处理程序
226 0
|
2月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
68 5
|
2月前
|
C语言
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性。本文探讨了C语言中的错误类型(如语法错误、运行时错误)、基本处理方法(如返回值、全局变量、自定义异常处理)、常见策略(如检查返回值、设置标志位、记录错误信息)及错误处理函数(如perror、strerror)。强调了不忽略错误、保持处理一致性及避免过度处理的重要性,并通过文件操作和网络编程实例展示了错误处理的应用。
75 4
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
65 1
|
2月前
|
网络协议 物联网 数据处理
C语言在网络通信程序实现中的应用,介绍了网络通信的基本概念、C语言的特点及其在网络通信中的优势
本文探讨了C语言在网络通信程序实现中的应用,介绍了网络通信的基本概念、C语言的特点及其在网络通信中的优势。文章详细讲解了使用C语言实现网络通信程序的基本步骤,包括TCP和UDP通信程序的实现,并讨论了关键技术、优化方法及未来发展趋势,旨在帮助读者掌握C语言在网络通信中的应用技巧。
47 2
|
2月前
|
程序员 C语言
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门。本文深入探讨了指针的基本概念、声明方式、动态内存分配、函数参数传递、指针运算及与数组和函数的关系,强调了正确使用指针的重要性,并鼓励读者通过实践掌握这一关键技能。
44 1