2021-10-12 51蛋骗鸡数码管前7位显示1-7第8位显示0-9

缘由 51单片机数码管问题-编程语言-CSDN问答

#include "REG52.h"
sbit K1 = P3^0;
sbit K2 = P3^1;
sbit K3 = P3^2;
sbit K4 = P3^3;
bit k=1,wk=0;
unsigned char code SmZiFu[]={63,6,91,79,102,109,125,7,127,111,128,255,64};//0-9.消隐-
unsigned char Js=0,miao=0,fen=0,shi=0,y=6,t=23,ls=0;//中断计时
unsigned int n=2021;
void smxs(unsigned char mz,unsigned char w,unsigned char d)
{unsigned char Xd=0;P1=~255;P1=~(255-(d==1?SmZiFu[mz]:(SmZiFu[mz]|0x80)));//小数点闪烁P2=~w;while(++Xd);
}
void sm(unsigned int n, unsigned char y, unsigned char t, unsigned char shi, unsigned char fen, unsigned char miao)
{smxs(k?miao%10:t%10,8,1);smxs(k?miao/10%10:t/10%10,4,1);smxs(k?255:y%10,2,0);smxs(k?fen%10:y/10%10,1,1);smxs(k?fen/10%10:n%10,128,k?1:0);smxs(k?255:n/10%10,64,k?0:1);smxs(k?shi%10:n/100%10,32,1);smxs(k?shi/10%10:n/1000,16,1);
}
unsigned char nyt(unsigned int n, unsigned char y)
{return (y == 2 ? (((!(n % 4) && n % 100) || !(n % 400)) ? 29 : 28) :(((y <= 7 && y % 2) || (y > 7 && !(y % 2))) ? 31 : 30));
}
void jw(unsigned int *n, unsigned char *y, unsigned char *t, unsigned char *shi, unsigned char *fen, unsigned char *miao)
{/*时间日期进位*/if(*miao>=60){*miao=0;++*fen;}if(*fen>=60){*fen=0;++*shi;}if(*shi>=24){*shi=0;++*t;}if(*t>nyt(*n,*y)){++*y;*t=1;}if(*y>12){++*n;*y=1;}
}
void JiShi(/*时间计算*/)
{if(Js>=20){Js=0;++miao;jw(&n, &y, &t, &shi, &fen, &miao);if(miao%5==0)k=~k;ls/=2;}
}
void wbzd(/*外部中断调用函数*/)
{unsigned char cs=10;unsigned int ys=0;wk=0;while(cs){if(++ys==0)--cs;if(cs%2==0)P1=1;else P1=128;}
}
void ZhongDuanSheZhi()
{TH0+=0X4c;/*定时器赋初值,定时50ms触发中断,自动补偿方式*/TL0+=0X00; TMOD=0X01;TR0=1;ET0=1; //开启定时器EA=1; //全局中断开关IT0 = 1;//下降沿触发EX0 = 1;//开外部中断
}
void main()
{unsigned char Xd=0,xz=0,cs=1,ss=0;unsigned int wei=0;P1=255;ZhongDuanSheZhi();while(1){if(++xz<8){smxs(xz,cs,1);//段数据,位数据,小数点选择cs*=2;//数码管位}else{smxs(ss,cs,1);xz=0;cs=1;if(++Xd==0&&++ss>9)ss=0;//第8位变动延时8*255*255}
//		if(++cs>9)cs=0;else;
//		if(K1==0&&++Xd==0){P1=0;while(K1==0);}
//		if(K2==0&&++Xd==0){P1=85;while(K2==0);}
//		if(K3==0&&++Xd==0){P1=15;while(K3==0);}
//		if(K4==0&&++Xd==0){P1=240;while(K4==0);}
//		if(K1==0&&++Xd==0)
//		{
//			k=~k;
//			if(xz>0)
//			{
//				TR0=1;
//				xz=0;
//			}
//			while(K1==0)smxs(xz,1,1);
//			Xd=240;
//		}//切换与确定
//		if(K2==0&&++Xd==0)
//		{
//			++xz;
//			while(K2==0)smxs(xz,1,1);
//			Xd=240;
//		}//xz值功能选择1年2月3天4时5分6秒7归零调节
//		if(xz)
//		{
//			TR0=0;
//			if(xz<4)
//				k=0;
//			else
//				k=1;
//			if(K3==0&&++Xd==0)
//			{
//				xz==1?++n:xz==2?++y:xz==3?++t:xz==4?++shi:xz==5?++fen:xz==6?++miao:0;
//				jw(&n, &y, &t, &shi, &fen, &miao);
//				while(K3==0);
//				Xd=240;
//			}
//			if(K4==0&&++Xd==0)
//			{
//				xz==1?--n:xz==2?--y:xz==3?--t:xz==4?--shi:xz==5?--fen:xz==6?--miao:0;
//				jw(&n, &y, &t, &shi, &fen, &miao);
//				while(K4==0);
//				Xd=240;
//			}
//			if(xz==1)
//				sm(n, 0, 0, 0, 0, 0);
//			else if(xz==2)
//				sm(0, y, 0, 0, 0, 0);
//			else if(xz==3)
//				sm(0, 0, t, 0, 0, 0);
//			else if(xz==4)
//				sm(0, 0, 0, shi, 0, 0);
//			else if(xz==5)
//				sm(0, 0, 0, 0, fen, 0);
//			else if(xz==6)
//				sm(0, 0, 0, 0, 0, miao);
//			if(xz==7)n=y=t=shi=fen=miao=0;
//			if(xz>7){xz=0;TR0=1;}
//		}
//		else
//			sm(n, y, t, shi, fen, miao);
//		P1=~ls;
//		if(ls==0){if(++cs<=5)ls=128;else {ls=0;cs=7;}}
//		if(wk)wbzd();
//		JiShi();}
}
void ZhongDuan() interrupt 1
{++Js;TH0+=0X4c;TL0+=0X00;        
}
void WaiBuZhongDuan0() interrupt 0//外部中断0=0,1=2,引脚P3.2,INT0
{wk=1; 
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/665609.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【MIT 6.S081】2020, 实验记录(5),Lab: lazy allocation

目录 Task 1: Eliminate allocation from sbrk()Task 2: Lazy allocationTask 3: Lazytests and Usertests 在学习了 page fault 这一节课后&#xff0c;了解了操作系统是如何结合 page table 和 trap 利用 page fault 来实现一系列的神奇的功能。这个 lab 就是在 XV6 中实现 l…

Java 数据类型详解与类型转换技巧

Java 数据类型 Java 中的变量必须是指定的数据类型&#xff1a; int myNum 5; // 整数 float myFloatNum 5.99f; // 浮点数 char myLetter D; // 字符 boolean myBool true; // 布尔值 String myText "Hello"; // 字符串数…

Codeforces Round 651 (Div. 2)C 博弈 奇偶数 偶数的表示

Submission #244500083 - Codeforces 题目&#xff1a; 思路&#xff1a; 此题要从奇偶性上入手。&#xff08;注意除的是奇因数&#xff0c;即一个奇数。我想成质数了&#xff09; 1.当A选手开局是1时&#xff0c;A败。 2.当A选手开局是2和奇数时&#xff0c;A必胜。&…

【Qt加密播放器】登录窗口功能补充

输入框小设计 目的&#xff1a;实现鼠标点击输入框时的聚焦效果。 首先在LoginForm构造函数中为账号和密码输入框添加事件过滤器。关于事件过滤器的具体介绍可以参考这篇博文&#xff1a;Qt消息机制和事件 ui->nameEdit->installEventFilter(this); ui->pwdEdit->…

常用换源总结

1.Ubuntu16.04更换国内源 在Ubuntu系统上使用apt-get install进行软件安装或更新的时候&#xff0c;由于使用的是国外源&#xff0c;导致下载速度很慢或者连接超时&#xff0c;需要更换下载源。 1.将系统原始的源文件进行备份 sudo cp /etc/apt/sources.list /etc/apt/source…

docker踩坑记录

踩坑记录 1.1 后台启动容器&#xff0c;实际没有启动 现象&#xff1a; 后台启动centos&#xff0c;结果执行docker ps命令&#xff0c;容器没启动。 原因&#xff1a; docker是以容器启动的&#xff0c;必须要有个前台进程&#xff0c;若是全部都是后台deamon守护进程&…

ChatGPT实战100例 - (12) 结构化提示词 LangGPT 实战

文章目录 ChatGPT实战100例 - (12) 结构化提示词 LangGPT 实战一、LangGPT是什么?二、远古诗人 vs 现代诗人三、LangGPT Role模板实战 - 甩锅王Role模板特征提取四、 用AI实现提示词结构化ChatGPT实战100例 - (12) 结构化提示词 LangGPT 实战 一、LangGPT是什么? 随着大模型…

代码随想录算法训练营第42天 | 01背包问题,你该了解这些! 01背包问题,你该了解这些! 滚动数组 416. 分割等和子集

目录 01背包问题&#xff0c;你该了解这些&#xff01; 01 背包 二维dp数组01背包 &#x1f4bb;实现代码 01背包问题&#xff0c;你该了解这些&#xff01; 滚动数组 一维dp数组&#xff08;滚动数组&#xff09; &#x1f4bb;实现代码 416. 分割等和子集 &#x1f…

前后端数据校验

前端校验内容 前端开发中的必要校验&#xff0c;可以保证用户输入的数据的准确性、合法性和安全性。同时&#xff0c;这些校验也有助于提供良好的用户体验和防止不必要的错误提交到后端。 1、必填字段校验&#xff1a; 对于必填的字段&#xff0c;需确保用户输入了有效的数据…

二叉树可视化

二叉树可视化 运行演示代码和程序已上传二叉树知识平衡二叉树红黑树最优二叉搜索树哈夫曼树KD树B树和B树 参考 运行演示 学习二叉树总是脑补图像&#xff0c;实在是恶心&#xff0c;就想写一个能可视化的二叉树&#xff0c;结果没控制好&#xff0c;功能越想越多&#xff0c;先…

腾讯面试题

目录 1 tcp可靠性&#xff0c;然后问十六位校验和怎么实现的 2 TCP粘包 3 进程协程线程 4 跳表怎么实现 5 gostruct能不能比较&#xff1f; 6 godefer&#xff08;fordefer&#xff09; 7 go select可以用于什么&#xff1f; 8 client如何实现长连接&#xff1f; 1. …

uniapp本地存储的几种方式localStorage

在uniapp开发中&#xff0c;本地存储是一个常见的需求。本地存储可以帮助我们在客户端保存和管理数据&#xff0c;以便在应用程序中进行持久化存储。本文将介绍uniapp中本地存储的几种方式&#xff0c;以及相关的代码示例。 介绍 在移动应用开发中&#xff0c;我们经常需要将…

Camille-学习笔记-SQL语法与数据库

# 数据库的基本概念 * 数据库简介 * 数据库分类 * 常用数据库简介 * 使用场景 * 数据库(DataBase) 就是一个以某种有组织的方式存储的数据集合 * 是存储和管理数据的仓库 * 其本质是一个文件系统 * 数据库管理系统&#xff08;DBMS&#xff09;是一款管理软件 ## 数据库分类 *…

红日三打靶!!!

红日三&#xff0c;黑盒测试 环境搭建一.外网打点1.网段探测2.端口服务扫描3.目录扫描4.网站漏洞扫描5.汇总&#xff0c;找破绽6.登陆MySQL改密码 7.进入后台&#xff0c;找能写马的地方8.蚁剑连接9.disable_functions绕过1.蚁剑插件绕过2.bypass_disablefunc_via_LD_PRELOAD绕…

Django模型(四)

一、数据操作初始化 from django.db import models# Create your models here. class Place(models.Model):"""位置信息"""name = models.CharField(max_length=32,verbose_name=地名)address = models.CharField(max_length=64,null=True,verbo…

利用OpenCV实现物流与生产线自动化的革命性突破

背景介绍&#xff1a; 在当今高度自动化的时代&#xff0c;物流和生产线上的每一个环节都关乎企业的核心竞争力。传统的生产方式往往依赖于人工检测和操作&#xff0c;这不仅效率低下&#xff0c;而且容易出错。为了解决这一问题&#xff0c;越来越多的企业开始寻求利用计算机视…

【高阶数据结构】红黑树

文章目录 前言什么是红黑树红黑树的性质红黑树结点的定义红黑树的插入情况一情况二情况三插入代码总结 验证是否为红黑树红黑树的删除 前言 前面我们学习了 AVL 树——高度平衡的二叉搜索树&#xff0c;AVL 树保证了结点的左右子树的高度差的绝对值不超过 1&#xff0c;也就是…

【正点原子STM32】STM32时钟系统(时钟树、时钟源、分频器和倍频系数、锁相环、STM32CubeMX时钟树、系统时钟配置步骤)

一、认识时钟树 1.1、什么是时钟&#xff1f;1.2、认识时钟树&#xff08;F1&#xff09;1.3、认识时钟树&#xff08;F4&#xff09;1.4、认识时钟树&#xff08;F7&#xff09;1.5、认识时钟树&#xff08;H7&#xff09; 二、配置系统时钟 2.1、系统时钟配置步骤2.2、外设…

绝世唐门:霍挂六个十万年魂环,一穿七灭团再现,淘汰赛顺利晋级

Hello,小伙伴们&#xff0c;我是拾荒君。 国漫《斗罗大陆2绝世唐门》第32期超前爆料&#xff0c;霍雨浩开局便释放六个十万年魂环&#xff0c;以绝对的气场碾压天灵学院代表队。首次参与高级魂师大赛&#xff0c;霍雨浩便大放异彩秀出超级霍挂&#xff0c;此等操作就连当初的唐…

LeetCode每日一题 | 1690. 石子游戏 VII

文章目录 题目描述问题分析程序代码 题目描述 原题链接 石子游戏中&#xff0c;爱丽丝和鲍勃轮流进行自己的回合&#xff0c;爱丽丝先开始 。 有 n 块石子排成一排。每个玩家的回合中&#xff0c;可以从行中 移除 最左边的石头或最右边的石头&#xff0c;并获得与该行中剩余石…