原题链接:蓝桥杯算法提高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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复