原题链接:蓝桥杯算法提高VIP-计算器
解题思路:
1. 把0-9的每个数字所对应的二极管开关情况分别用0和1给表示出来
2. 对当前数字和目标数字做按位异或操作,即判断两者的二极管开关情况是否为01,如果是那就是变换一次,则记录一下
本来想着手工算一遍0-9每个数字所对应目标数的变换次数,可当我算完0至(1-9)时眼就好花QWQ,所以就有了这个思路QWQ。
参考代码:
#include <stdio.h> int main(){ int table[10][7] = { //0-9每个数字所对应的二极管开关情况 {1,1,1,0,1,1,1}, {0,0,1,0,0,1,0}, {1,0,1,1,1,0,1}, {1,0,1,1,0,1,1}, {0,1,1,1,0,1,0}, {1,1,0,1,0,1,1}, {1,1,0,1,1,1,1}, {1,0,1,0,0,1,0}, {1,1,1,1,1,1,1}, {1,1,1,1,0,1,1} }; char a[100],b[100]; int i,j,l,count = 0; scanf("%d", &l); scanf("%s", a); scanf("%s", b); for(i = 0; i < l; i++){ for(j = 0; j < 7; j++){ if(table[a[i]-'0'][j]^table[b[i]-'0'][j] == 1){ count++; } } } printf("%d", count); return 0; }
0.0分
5 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复