专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
c有没有什么方法把比如"25*10+1"的字符串计算出来?
2019-12-22 13:44
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
14466
20
20
现在解释器有这个功能,但是我是用C工程开发,需要这个字符串计算机功能
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
19条回答
关于以后
1楼-- · 2019-12-24 17:38
递归的方法发一波。
之前一直在用的。
/**
* @brief Four arithmetic operation.
* @param *s: Expression start.
* @param *e: Expression end
* @retval ret
*/
int calc(const char *s, const char *e)
{
int layer = 0;
const char *p;
for (p = e; p >= s; --p) {
switch (*p) {
case ')': ++layer; break;
case '(': --layer; break;
case '+':
if (0 == layer) return calc(s, p - 1) + calc(p + 1, e);
break;
case '-':
if (0 == layer) return calc(s, p - 1) - calc(p + 1, e);
break;
}
}
for (p = e; p >= s; --p) {
switch (*p) {
case ')': ++layer; break;
case '(': --layer; break;
case '*':
if (0 == layer) return calc(s, p - 1) * calc(p + 1, e);
break;
case '/':
if (0 == layer) return calc(s, p - 1) / calc(p + 1, e);
break;
}
}
if ('(' == *s && ')' == *e) return calc(s + 1, e - 1);
return atoi(s);
}
复制代码
加载中...
上一页
1
2
3
4
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
STM32开发板免费用活动
7 个回答
stm32 处理 DHT11占用太多时间,大家程序是怎么设计的
8 个回答
分享一个STM32单片机做的离线编程器代码
9 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
之前一直在用的。
- /**
- * @brief Four arithmetic operation.
- * @param *s: Expression start.
- * @param *e: Expression end
- * @retval ret
- */
- int calc(const char *s, const char *e)
- {
- int layer = 0;
- const char *p;
-
- for (p = e; p >= s; --p) {
- switch (*p) {
- case ')': ++layer; break;
- case '(': --layer; break;
- case '+':
- if (0 == layer) return calc(s, p - 1) + calc(p + 1, e);
- break;
- case '-':
- if (0 == layer) return calc(s, p - 1) - calc(p + 1, e);
- break;
- }
- }
-
- for (p = e; p >= s; --p) {
- switch (*p) {
- case ')': ++layer; break;
- case '(': --layer; break;
- case '*':
- if (0 == layer) return calc(s, p - 1) * calc(p + 1, e);
- break;
-
- case '/':
- if (0 == layer) return calc(s, p - 1) / calc(p + 1, e);
- break;
- }
- }
-
- if ('(' == *s && ')' == *e) return calc(s + 1, e - 1);
- return atoi(s);
- }
复制代码一周热门 更多>