题解学习 CCF 2019-3 二十四点游戏

CCF 2019-3 二十四点游戏

(学习 题解总结)
恩师的题解,总是充满了感动———总是那么精简,耗时总是所有题解中最少的。二十四点游戏竟然耗时0ms,下面聊聊我自己的学习体会以及中间走过的坑:
1.运算符和数字分别用char op[3]和int a[4]来存储,中间有一个a[i] = s[2 * i] - '0';,这是由于字符数组中存储的是ASCII码,减去‘0’才是真正存储的数字;

2.该题解使用了judge函数,不像以前见过的是 :void 函数名() 的画风,这是因为返回的,是该函数所得结果是否是24的问题。

3.数字和运算符存储好后,主要让人头疼的便是运算优先级了:先算’x’,’/’!
因此正如题解中所写:

for(i = 0; i < k; i++)
    	if(op[i] == 'x' || op[i] == '/'){
	    	if(op[i] == 'x')
	    	   a[i] = a[i] * a[i + 1];
	    	else
	    	   a[i] = a[i] / a[i + 1];
	    	for(j = i + 1; j < k; j++){
	    		op[j - 1] = op[j];
	    		a[j] = a[j + 1];
			}
			k--, i--;
	}

中间还好说,但之后的for循环就让我蒙圈了。经过手动的推导,才发现这和if语句中
`a[i] = a[i] + a[i + 1];
有关,就举“6x4+4/5”的例子吧:因为这样a[0]和a[1]合为a[0],自然后面存储数字和字符的下标都要提前因此有

for(j = i + 1; j < k; j++){
	    		op[j - 1] = op[j];
	    		a[j] = a[j + 1];
			}

而总体也少一,因此 k- -,而又因为之前将运算结果都给了a[i],故i- -.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值