要求:对下列代码进行注释 代码如下:#include "reg51.h" sbit smg1=P2^0;//数码管 sbit smg2=P2^1; sbit smg3=P2^2; sbit smg4=P2^3; sbit smg5=P2^4; sbit smg6=P2^5; unsigned int a=0,b=0; //输入 unsigned char fuhao=0;//符号 unsigned int c=0;//结果 unsigned char code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//0~9 void delay(unsigned int i)//延时函数 { while(i--); } unsigned char key_scan()//按键检测 { unsigned char i,j; i=0; j=0; P1=0x0f; if(P1!=0x0f) //被按下 { switch(P1)//检测行 { case 0x0e:i=3;break;//第四行 case 0x0d:i=2;break;//第三行 case 0x0b:i=1;break;//第二行 case 0x07:i=0;//第一行 } P1=0xf0; switch(P1)//检测列 { case 0xe0:j=13;break;//第四列 case 0xd0:j=9;break;//第三列 case 0xb0:j=5;break;//第二列 case 0x70:j=1;//第一列 } while(P1!=0xf0);//等待按键松开 } return i+j; } void main()//主函数 { unsigned char i; while(1) { //显示功能 if(fuhao<5) {//第一个数 P0=smgduan[a%10];smg1=0;delay(100);smg1=1;//第一个数 switch(fuhao)//符号 { case 1:P0=0x01;break;//加 case 2:P0=0x40;break;//减 case 3:P0=0x08;break;//乘 case 4:P0=0x80;break;//除 default:P0=0; } smg2=0;delay(100);smg2=1;//符号 P0=smgduan[b%10];smg3=0;delay(100);smg3=1;//第二个数 } else//计算结果 { P0=0x09;smg1=0;delay(100);smg1=1;//等于 //结果 P0=smgduan[c%100/10];smg2=0;delay(100);smg2=1;//十位 P0=smgduan[c%10];smg3=0;delay(100);smg3=1;//个位 } //计算功能 i=key_scan();//检测 if((i>0)&&(i<11))//输入数值 { if(fuhao==0)//第一个数 { a=i-1; } else //第二个数 { b=i-1; } } if(i==13)//加 { fuhao=1; } if(i==14)//减 { fuhao=2; } if(i==15)//乘 { fuhao=3; } if(i==16)//除 { fuhao=4; } if(i==11)//等于 { switch(fuhao) { case 1:c=a+b;break; case 2:c=a-b;break; case 3:c=a;c=c*b;break; case 4:c=a/b; } fuhao=5; } if(i==12)//归零 { a=0; b=0; c=0; fuhao=0; } } }

时间: 2024-04-07 18:29:40 浏览: 22
注释如下: #include "reg51.h" //包含头文件reg51.h,该头文件是51单片机的寄存器定义文件 sbit smg1=P2^0;//数码管1 sbit smg2=P2^1;//数码管2 sbit smg3=P2^2;//数码管3 sbit smg4=P2^3;//数码管4 sbit smg5=P2^4;//数码管5 sbit smg6=P2^5;//数码管6 unsigned int a=0,b=0; //定义两个无符号整型变量a和b并初始化为0 unsigned char fuhao=0;//定义一个无符号字符型变量fuhao并初始化为0,用于记录运算符号 unsigned int c=0;//定义一个无符号整型变量c并初始化为0,用于记录结果 unsigned char code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//定义一个只读的字符型数组smgduan,用于存储0~9的七段数码管显示编码 void delay(unsigned int i)//定义一个延时函数,参数为一个无符号整型变量i { while(i--); //i自减,当i为0时跳出循环 } unsigned char key_scan()//定义一个按键检测函数,返回一个无符号字符型变量 { unsigned char i,j; //定义两个无符号字符型变量i和j,用于记录行和列 i=0; //将i初始化为0 j=0; //将j初始化为0 P1=0x0f; //将P1的低4位设为0,用于检测行 if(P1!=0x0f) //如果P1的低4位不为0x0f,说明有按键被按下 { switch(P1) //检测行 { case 0x0e:i=3;break;//第四行 case 0x0d:i=2;break;//第三行 case 0x0b:i=1;break;//第二行 case 0x07:i=0;//第一行 } P1=0xf0; //将P1的高4位设为0,用于检测列 switch(P1) //检测列 { case 0xe0:j=13;break;//第四列 case 0xd0:j=9;break;//第三列 case 0xb0:j=5;break;//第二列 case 0x70:j=1;//第一列 } while(P1!=0xf0);//等待按键松开 } return i+j; //返回行列之和 } void main()//主函数 { unsigned char i; //定义一个无符号字符型变量i while(1) //无限循环 { //显示功能 if(fuhao<5) //如果运算符号小于5,说明在输入第一个数或运算符号 { //显示第一个数 P0=smgduan[a%10];smg1=0;delay(100);smg1=1;//取a的个位数并显示 switch(fuhao) //显示运算符号 { case 1:P0=0x01;break;//加 case 2:P0=0x40;break;//减 case 3:P0=0x08;break;//乘 case 4:P0=0x80;break;//除 default:P0=0; } smg2=0;delay(100);smg2=1;//显示运算符号 P0=smgduan[b%10];smg3=0;delay(100);smg3=1;//取b的个位数并显示 } else //如果运算符号为5,说明需要计算结果 { P0=0x09;smg1=0;delay(100);smg1=1;//显示等于号 P0=smgduan[c%100/10];smg2=0;delay(100);smg2=1;//取c的十位数并显示 P0=smgduan[c%10];smg3=0;delay(100);smg3=1;//取c的个位数并显示 } //计算功能 i=key_scan();//检测按键 if((i>0)&&(i<11))//如果输入的是数字键 { if(fuhao==0)//如果运算符号为0,说明在输入第一个数 { a=i-1; //将输入的数字存入a } else //如果运算符号不为0,说明在输入第二个数 { b=i-1; //将输入的数字存入b } } if(i==13)//如果输入的是加号 { fuhao=1; //设置运算符号为1 } if(i==14)//如果输入的是减号 { fuhao=2; //设置运算符号为2 } if(i==15)//如果输入的是乘号 { fuhao=3; //设置运算符号为3 } if(i==16)//如果输入的是除号 { fuhao=4; //设置运算符号为4 } if(i==11)//如果输入的是等于号 { switch(fuhao) //根据运算符号进行计算 { case 1:c=a+b;break;//加 case 2:c=a-b;break;//减 case 3:c=a*c;break;//乘 case 4:c=a/b;break;//除 } fuhao=5; //设置运算符号为5,表示已经计算出结果 } if(i==12)//如果输入的是归零键 { a=0; b=0; c=0; fuhao=0; //将a、b、c、fuhao全部清零 } } }

相关推荐

要求:分析代码 代码如下:#include "reg51.h" sbit smg1=P2^0;//数码管 sbit smg2=P2^1; sbit smg3=P2^2; sbit smg4=P2^3; sbit smg5=P2^4; sbit smg6=P2^5; unsigned int a=0,b=0; //输入 unsigned char fuhao=0;//符号 unsigned int c=0;//结果 unsigned char code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//0~9 void delay(unsigned int i)//延时函数 { while(i--); } unsigned char key_scan()//按键检测 { unsigned char i,j; i=0; j=0; P1=0x0f; if(P1!=0x0f) //被按下 { switch(P1)//检测行 { case 0x0e:i=3;break;//第四行 case 0x0d:i=2;break;//第三行 case 0x0b:i=1;break;//第二行 case 0x07:i=0;//第一行 } P1=0xf0; switch(P1)//检测列 { case 0xe0:j=13;break;//第四列 case 0xd0:j=9;break;//第三列 case 0xb0:j=5;break;//第二列 case 0x70:j=1;//第一列 } while(P1!=0xf0);//等待按键松开 } return i+j; } void main()//主函数 { unsigned char i; while(1) { //显示功能 if(fuhao<5) {//第一个数 P0=smgduan[a%10];smg1=0;delay(100);smg1=1;//第一个数 switch(fuhao)//符号 { case 1:P0=0x01;break;//加 case 2:P0=0x40;break;//减 case 3:P0=0x08;break;//乘 case 4:P0=0x80;break;//除 default:P0=0; } smg2=0;delay(100);smg2=1;//符号 P0=smgduan[b%10];smg3=0;delay(100);smg3=1;//第二个数 } else//计算结果 { P0=0x09;smg1=0;delay(100);smg1=1;//等于 //结果 P0=smgduan[c%100/10];smg2=0;delay(100);smg2=1;//十位 P0=smgduan[c%10];smg3=0;delay(100);smg3=1;//个位 } //计算功能 i=key_scan();//检测 if((i>0)&&(i<11))//输入数值 { if(fuhao==0)//第一个数 { a=i-1; } else //第二个数 { b=i-1; } } if(i==13)//加 { fuhao=1; } if(i==14)//减 { fuhao=2; } if(i==15)//乘 { fuhao=3; } if(i==16)//除 { fuhao=4; } if(i==11)//等于 { switch(fuhao) { case 1:c=a+b;break; case 2:c=a-b;break; case 3:c=a;c=c*b;break; case 4:c=a/b; } fuhao=5; } if(i==12)//归零 { a=0; b=0; c=0; fuhao=0; } } }

要求:分析各部分代码 代码如下:#include "reg51.h" sbit smg1=P2^0;//数码管 sbit smg2=P2^1; sbit smg3=P2^2; sbit smg4=P2^3; sbit smg5=P2^4; sbit smg6=P2^5; unsigned int a=0,b=0; //输入 unsigned char fuhao=0;//符号 unsigned int c=0;//结果 unsigned char code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//0~9 void delay(unsigned int i)//延时函数 { while(i--); } unsigned char key_scan()//按键检测 { unsigned char i,j; i=0; j=0; P1=0x0f; if(P1!=0x0f) //被按下 { switch(P1)//检测行 { case 0x0e:i=3;break;//第四行 case 0x0d:i=2;break;//第三行 case 0x0b:i=1;break;//第二行 case 0x07:i=0;//第一行 } P1=0xf0; switch(P1)//检测列 { case 0xe0:j=13;break;//第四列 case 0xd0:j=9;break;//第三列 case 0xb0:j=5;break;//第二列 case 0x70:j=1;//第一列 } while(P1!=0xf0);//等待按键松开 } return i+j; } void main()//主函数 { unsigned char i; while(1) { //显示功能 if(fuhao<5) {//第一个数 P0=smgduan[a%10];smg1=0;delay(100);smg1=1;//第一个数 switch(fuhao)//符号 { case 1:P0=0x01;break;//加 case 2:P0=0x40;break;//减 case 3:P0=0x08;break;//乘 case 4:P0=0x80;break;//除 default:P0=0; } smg2=0;delay(100);smg2=1;//符号 P0=smgduan[b%10];smg3=0;delay(100);smg3=1;//第二个数 } else//计算结果 { P0=0x09;smg1=0;delay(100);smg1=1;//等于 //结果 P0=smgduan[c%100/10];smg2=0;delay(100);smg2=1;//十位 P0=smgduan[c%10];smg3=0;delay(100);smg3=1;//个位 } //计算功能 i=key_scan();//检测 if((i>0)&&(i<11))//输入数值 { if(fuhao==0)//第一个数 { a=i-1; } else //第二个数 { b=i-1; } } if(i==13)//加 { fuhao=1; } if(i==14)//减 { fuhao=2; } if(i==15)//乘 { fuhao=3; } if(i==16)//除 { fuhao=4; } if(i==11)//等于 { switch(fuhao) { case 1:c=a+b;break; case 2:c=a-b;break; case 3:c=a;c=c*b;break; case 4:c=a/b; } fuhao=5; } if(i==12)//归零 { a=0; b=0; c=0; fuhao=0; } } }

#include <reg51.h> #define SMG P0 //定义数码管段数据接口P0 typedef unsigned long ulong; //对数据类型进行声明定义 typedef unsigned int uint; typedef unsigned char uchar; sbit LSA=P2^2; //74hc138的A B C引脚定义 sbit LSB=P2^3; sbit LSC=P2^4; uchar buff[8]; //显示缓冲数组 uchar a[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};//共阴数码管 void delayms(uchar ms) { uchar i; while(ms--) for(i=0; i<123; i++); } void update(ulong val) //更新缓冲数组 { //分离各位数据 buff[0]=val/10000000%10; //12345678/10000000%10=1; buff[1]=val/1000000%10; //12345678/1000000%10=2; buff[2]=val/100000%10; //12345678/100000%10=3; buff[3]=val/10000%10; //12345678/10000%10=4; buff[4]=val/1000%10; //12345678/1000%10=5; buff[5]=val/100%10; //12345678/100%10=6; buff[6]=val/10%10; //12345678/10%10=7; buff[7]=val%10; //12345678%10=8; } void display(void) //显示函数 { uchar n; for(n=0; n<8; n++) { switch(n) //先位选 { case 0:LSC=0;LSB=0;LSA=0;break; case 1:LSC=0;LSB=0;LSA=1;break; case 2:LSC=0;LSB=1;LSA=0;break; case 3:LSC=0;LSB=1;LSA=1;break; case 4:LSC=1;LSB=0;LSA=0;break; case 5:LSC=1;LSB=0;LSA=1;break; case 6:LSC=1;LSB=1;LSA=0;break; case 7:LSC=1;LSB=1;LSA=1;break; } SMG=a[buff[n]]; //后发送段数据 delayms(1); //小延时,显示更稳定 } } void main(void) { ulong num=0; //要显示的数据 uchar t; //延时用 while(1) { update(num); //更新显示缓冲数组 for(t=0; t<50; t++) //用for循环来延时不然显示不正常 { display(); //显示缓冲数组 } num++; //显示数据自加 } }

#include "reg52.h" typedef unsigned int u16;//对系统默认数据类型进行重定义 typedef unsigned char u8; #define SMG_A_DP_PORT P0 //使用宏定义数码管段码口 //定义数码管位选信号控制脚 sbit LSA=P2^2; sbit LSB=P2^3; sbit LSC=P2^4; //共阴极数码管显示 0~F 的段码数据 u8 gsmg_code[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71}; /******************************************************************************* * 函 数 名 : delay_10us * 函数功能 : 延时函数,ten_us=1 时,大约延时 10us * 输 入 : ten_us * 输 出 : 无 145 *******************************************************************************/ void delay_10us(u16 ten_us) { while(ten_us--); } /******************************************************************************* * 函 数 名 : smg_display * 函数功能 : 动态数码管显示 * 输 入 : 无 * 输 出 : 无 *******************************************************************************/ void smg_display(void) { u8 i=0; for(i=0;i<8;i++) { switch(i)//位选 { case 0: LSC=1;LSB=1;LSA=1;break; case 1: LSC=1;LSB=1;LSA=0;break; case 2: LSC=1;LSB=0;LSA=1;break; case 3: LSC=1;LSB=0;LSA=0;break; case 4: LSC=0;LSB=1;LSA=1;break; case 5: LSC=0;LSB=1;LSA=0;break; case 6: LSC=0;LSB=0;LSA=1;break; case 7: LSC=0;LSB=0;LSA=0;break; } SMG_A_DP_PORT=gsmg_code[i];//传送段选数据 delay_10us(100);//延时一段时间,等待显示稳定 SMG_A_DP_PORT=0x00;//消音 } } /******************************************************************************* * 函 数 名 : main * 函数功能 : 主函数 * 输 入 : 无 * 输 出 : 无 *******************************************************************************/ void main() { while(1) { smg_display(); } }

最新推荐

recommend-type

06_QLibrary.zip

06_QLibrary.zip
recommend-type

毕业设计: 基于Densenet + CTC技术的文字检测识别的技术研究

本毕设课题是属于计算机视觉下的目标检测与识别,对象为自然场景下的各种文本信息,通俗的说就是检测识别图片中的文本信息。由于文本的特殊性,本毕设将整个提取信息的过程可以分为检测、识别两个部分。 论文对用到的相关技术概念有一定的介绍分析,如机器学习,深度学习,以及各种的网络模型及其工作原理过程。 检测部分采用水平检测文本线方式进行文本检测,主要参考了乔宇老师团队的 CTPN 方法,并在正文部分从模型的制作到神经网络的设计实现对系统进行了较为详细的分析介绍。 识别部分则采用的是 Densenet + CTC,对于印刷体的文字有较好的识别。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解答下列问题:S—>S;T|T;T—>a 构造任意项目集规范族,构造LR(0)分析表,并分析a;a

对于这个文法,我们可以构造以下项目集规范族: I0: S -> .S S -> .T T -> .a I1: S -> S. [$ T -> T. [$ I2: S -> T. I3: S -> S.;S S -> S.;T T -> T.;a 其中,点(.)表示已经被扫描过的符号,;$表示输入串的结束符号。 根据项目集规范族,我们可以构造出LR(0)分析表: 状态 | a | $ ---- | - | - I0 | s3| I1 | |acc I2 | | 其中s3表示移进到状态3,acc表示接受。在分析字符串a;a时,我们可以按照以下步骤进行
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这
recommend-type

mac上和window原生一样的历史剪切板工具有什么

好的,我明白了您的要求。关于您的问题,为使Mac与Windows的历史剪切板功能类似,可以使用第三方工具"CopyClip"、"Alfred"、"Clipboard Manager"等。这些工具可以记录您复制到剪切板的所有内容,而不仅仅是最后一次复制。同时,它们还可以进行搜索和过滤,以便您更快地找到需要的内容。希望这能回答您的问题。