第十二届蓝桥杯单片机国赛真题

2024-05-10 06:28

本文主要是介绍第十二届蓝桥杯单片机国赛真题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

有问题欢迎大家指出,共同交流学习进步

#include <STC15F2K60S2.H>
#include "ds1302.h"
#include "intrins.h"
#include "iic.h"
#define TSMG 500
sbit TX = P1^0;
sbit RX = P1^1;
sbit h3 = P3^2;
sbit h4 = P3^3;
sbit s1 = P4^4;
sbit s2 = P4^2;
code unsigned char Seg_dot[] = {0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};
code unsigned char Seg_Table[] = {0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};
code unsigned char read_addre[] = {0x81,0x83,0x85,0x87,0x89,0x8b,0x8d};
code unsigned char write_addre[] = {0x80,0x82,0x84,0x86,0x88,0x8a,0x8c};
code unsigned char INIT_timer[] = {0x01,0x20,0x20,0x08,0x05,0x03,0x24};
unsigned char t_h = 0;
unsigned char t_m = 0;
unsigned char t_s = 0;
unsigned int distance = 0;
unsigned char UI = 0;//0-数据显示界面 1-参数显示界面
unsigned char UI_data = 0;//0-时间显示 1-距离显示 2-数据记录
unsigned char UI_param = 0;//0-采集时间参数 1-距离参数
unsigned char stat_value = 0;//0-最大值 1-最小值 2-平均值
unsigned char max_value = 0;
unsigned char min_value = 0;
float aver_value = 0;
unsigned char timer_param = 2;
unsigned char dis_param = 20;
unsigned char dis_mode = 0;//0-触发模式 1-定时模式
unsigned char adc_value = 0;
unsigned char old_value = 0;
unsigned int aver_smg = 0;
unsigned char Sec = 0;
unsigned char stat_old = 0;
unsigned stat_Sec = 0;
unsigned char warn = 0;
unsigned char num = 0;
unsigned char stat_led = 0xff;
unsigned char count_200ms = 0;
unsigned char adc_value1 = 0;
void Delay20ms()		//@12.000MHz
{unsigned char i, j, k;_nop_();_nop_();i = 1;j = 234;k = 113;do{do{while (--k);} while (--j);} while (--i);
}void Delay12us()		//@12.000MHz
{unsigned char i;_nop_();_nop_();i = 33;while (--i);
}
unsigned char read_myadc()
{unsigned char adc_dat;I2CStart();I2CSendByte(0x90);I2CWaitAck();I2CSendByte(0x41);I2CWaitAck();I2CStop();I2CStart();I2CSendByte(0x91);I2CWaitAck();adc_dat = I2CReceiveByte();I2CSendAck(1);I2CStop();return adc_dat;
}
void set_mydac(unsigned char value)
{I2CStart();I2CSendByte(0x90);I2CWaitAck();I2CSendByte(0x41);I2CWaitAck();I2CSendByte(value);I2CWaitAck();I2CStop();
}
void send_Wave()
{unsigned char i;for(i = 0;i < 8;i++){TX = 1;Delay12us();TX = 0;Delay12us();}
}
void measure_distan()
{unsigned int timer;CMOD = 0x00;CCON = 0x00;CL = CH = 0;send_Wave();CR = 1;while((RX == 1) && (CF == 0));CR = 0;if(CF == 0){timer = (CH << 8) | CL;distance = timer * 0.0172;}else{CF = 0;distance = 999;}
}
void Init_mytimer()
{unsigned char i;Write_Ds1302_Byte(0x8e,0x00);for(i == 0;i < 7;i++){Write_Ds1302_Byte(write_addre[i],INIT_timer[i]);}Write_Ds1302_Byte(0x8e,0x80);
}
void read_mytimer()
{t_h = Read_Ds1302_Byte(0x85);t_m = Read_Ds1302_Byte(0x83);t_s = Read_Ds1302_Byte(0x81);
}
void SelectHC573(unsigned char channel,unsigned char dat)
{P2 = (P2 & 0x1f) | 0x00;P0 = dat;switch(channel){case 4:P2 = (P2 & 0x1f) | 0x80;break;case 5:P2 = (P2 & 0x1f) | 0xa0;break;case 6:P2 = (P2 & 0x1f) | 0xc0;break;case 7:P2 = (P2 & 0x1f) | 0xe0;break;case 0:P2 = (P2 & 0x1f) | 0x00;break;}P2 = (P2 & 0x1f) | 0x00;
}
void DelaySMG(unsigned int t)
{while(t--);
}
void DisplaySMG_Bit(unsigned char pos,unsigned char value)
{SelectHC573(6,0x01 << pos);SelectHC573(7,value);DelaySMG(TSMG);SelectHC573(6,0x01 << pos);SelectHC573(7,0xff);
}
void DisplaySMG_All(unsigned char value)
{SelectHC573(6,0xff);SelectHC573(7,value);
}
void DisplaySMG_Info()
{if(UI == 0){switch(UI_data){case 0:DisplaySMG_Bit(0,Seg_Table[t_h >> 4]);DisplaySMG_Bit(1,Seg_Table[t_h & 0x0f]);DisplaySMG_Bit(2,0xbf);DisplaySMG_Bit(3,Seg_Table[t_m >> 4]);DisplaySMG_Bit(4,Seg_Table[t_m & 0x0f]);DisplaySMG_Bit(5,0xbf);DisplaySMG_Bit(6,Seg_Table[(t_s & 0x7f) >> 4]);DisplaySMG_Bit(7,Seg_Table[t_s & 0x0f]);break;case 1:DisplaySMG_Bit(0,0xc7);if(dis_mode == 0){DisplaySMG_Bit(1,0xc6);}else if(dis_mode == 1){DisplaySMG_Bit(1,0x8e);}if(distance > 99)DisplaySMG_Bit(5,Seg_Table[distance / 100]);if(distance > 9) DisplaySMG_Bit(6,Seg_Table[distance / 10 % 10]);DisplaySMG_Bit(7,Seg_Table[distance % 10]);break;case 2:DisplaySMG_Bit(0,0x89);switch(stat_value){case 0:DisplaySMG_Bit(1,0xfe);if(max_value > 999)DisplaySMG_Bit(4,Seg_Table[max_value / 1000]);if(max_value > 99)DisplaySMG_Bit(5,Seg_Table[max_value / 100 % 10]);if(max_value > 9)DisplaySMG_Bit(6,Seg_Table[max_value / 10 % 10]);DisplaySMG_Bit(7,Seg_Table[max_value % 10]);break;case 1:DisplaySMG_Bit(1,0xbf);if(aver_smg > 999)DisplaySMG_Bit(4,Seg_Table[aver_smg / 1000]);if(aver_smg > 99)DisplaySMG_Bit(5,Seg_Table[aver_smg / 100 % 10]);DisplaySMG_Bit(6,Seg_dot[aver_smg / 10 % 10]);DisplaySMG_Bit(7,Seg_Table[aver_smg % 10]);break;case 2:DisplaySMG_Bit(1,0xf7);if(min_value > 999)DisplaySMG_Bit(4,Seg_Table[min_value / 1000]);if(min_value > 99)DisplaySMG_Bit(5,Seg_Table[min_value / 100 % 10]);if(min_value > 9)DisplaySMG_Bit(6,Seg_Table[min_value / 10 % 10]);DisplaySMG_Bit(7,Seg_Table[min_value % 10]);break;}break;}}else{if(UI_param == 0){DisplaySMG_Bit(0,0x8c);DisplaySMG_Bit(1,Seg_Table[1]);DisplaySMG_Bit(6,Seg_Table[timer_param / 10]);DisplaySMG_Bit(7,Seg_Table[timer_param % 10]);}else if(UI_param == 1){DisplaySMG_Bit(0,0x8c);DisplaySMG_Bit(1,Seg_Table[2]);DisplaySMG_Bit(6,Seg_Table[dis_param / 10]);DisplaySMG_Bit(7,Seg_Table[dis_param % 10]);}}
}
void Scan_key()
{h3 = 0;h4 = s1 = s2 = 1;if(s1 == 0)//s5{Delay20ms();if(s1 == 0){if(UI == 0){if(UI_data == 0){UI_data = 1;}else if(UI_data == 1){stat_value = 0;UI_data = 2;}else if(UI_data == 2){UI_data = 0;}}if(UI == 1){if(UI_param == 0){UI_param = 1;}else if(UI_param == 1){UI_param = 0;}}while(s1 == 0);}}else if(s2 == 0)//s9{Delay20ms();if(s2 == 0){if((UI == 1) && (UI_param == 0)){if(timer_param == 2){timer_param = 3;}else if(timer_param == 3){timer_param = 5;}else if(timer_param == 5){timer_param = 7;}else if(timer_param == 7){timer_param = 9;}else if(timer_param == 9){timer_param = 2;}}if((UI == 1) && (UI_param == 1)){if(dis_param == 80){dis_param = 10;}else{dis_param += 10;}}while(s2 == 0);}}h4 = 0;h3 = s1 = s2 = 1;if(s1 == 0)//s4{Delay20ms();if(s1 == 0){if(UI == 0){UI_param = 0;UI = 1;}else{UI_data = 0;UI = 0;}while(s1 == 0);}}else if(s2 == 0)//s8{Delay20ms();if(s2 == 0){if((UI == 0) && (UI_data == 2)){if(stat_value == 0){stat_value = 1;}else if(stat_value == 1){stat_value = 2;}else if(stat_value == 2){stat_value = 0;}}if((UI == 0) && (UI_data == 1)){if(dis_mode == 0){dis_mode = 1;}else if(dis_mode == 1){dis_mode = 0;}}while(s2 == 0);}}
}
void deal_distance()
{static unsigned char i = 0;if(dis_mode == 0)//触发模式{adc_value = read_myadc();if((old_value > 50) && (adc_value < 50)){measure_distan();if(stat_old == 0){min_value = distance;stat_old = 1;}i++;aver_value = (aver_value * (i-1) + distance) / i;}old_value = adc_value;}else if(dis_mode == 1)//定时模式{Sec = (t_s / 16) * 10 + t_s % 16;if((Sec % timer_param) == 0){if(stat_Sec != Sec){stat_Sec = Sec;//防止多次测量measure_distan();if(stat_old == 0){min_value = distance;stat_old = 1;}i++;aver_value = (aver_value * (i-1) + distance) / i;if(((dis_param + 5) >= distance)&& (distance >= (dis_param - 5))){num++;if(num == 3){num = 0;warn = 1;}}else{warn = 0;}}}			}if(distance > max_value){max_value = distance;}if(distance < min_value){min_value = distance;}aver_smg = aver_value * 10;if(i == 5){i = 0;}
}
void led_control()
{if((UI == 0) && (UI_data == 0)){stat_led |= 0x04;stat_led &= 0xfe;}if((UI == 0) && (UI_data == 1)){stat_led |= 0x01;stat_led &= 0xfd;}if((UI == 0) && (UI_data == 2)){stat_led |= 0x02;stat_led &= 0xfb;}if(dis_mode == 0){stat_led &= 0xf7;}else{stat_led |= 0x08;}if(warn == 1){stat_led &= 0xef;}else{stat_led |= 0x10;}if(adc_value1 > 50){stat_led &= 0xdf;}else{stat_led |= 0x20;}SelectHC573(4,stat_led);
}
void dac_output()
{unsigned char dac_value;if(distance < 10){set_mydac(51);}else if(distance <= 80){dac_value = (((4.0/70) * distance + (3.0 / 7)) / (5.0 / 255));set_mydac(dac_value);}else{set_mydac(255);}
}
void Timer0Init(void)		//10毫秒@12.000MHz
{AUXR &= 0x7F;		//定时器时钟12T模式TMOD &= 0xF0;		//设置定时器模式TMOD |= 0x01;		//设置定时器模式TL0 = 0xF0;		//设置定时初值TH0 = 0xD8;		//设置定时初值TF0 = 0;		//清除TF0标志TR0 = 1;		//定时器0开始计时ET0 = 1;EA = 1;
}
void sevice_timer0() interrupt 1
{TL0 = 0xF0;		//设置定时初值TH0 = 0xD8;		//设置定时初值DisplaySMG_Info();read_mytimer();count_200ms++;if(count_200ms == 20){count_200ms = 0;adc_value1 = read_myadc();}
}
void main()
{Timer0Init();Init_mytimer();DisplaySMG_All(0xff);SelectHC573(4,0xff);SelectHC573(5,0x00);while(1){Scan_key();deal_distance();led_control();dac_output();}
}

这篇关于第十二届蓝桥杯单片机国赛真题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/975684

相关文章

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

单片机毕业设计基于单片机的智能门禁系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍程序代码部分参考 设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订

华为OD机试真题-学生方阵-2024年OD统一考试(E卷)

题目描述 学校组织活动,将学生排成一个矩形方阵。 请在矩形方阵中找到最大的位置相连的男生数量。这个相连位置在一个直线上,方向可以是水平的,垂直的,成对角线的或者呈反对角线的。 注:学生个数不会超过10000 输入描述 输入的第一行为矩阵的行数和列数, 接下来的 n行为矩阵元素,元素间用""分隔。 输出描述 输出一个整数,表示矩阵中最长的位

C语言蓝桥杯

一、语言基础 竞赛常用库函数 最值查询 min_element和max_element在vector(迭代器的使用) nth_element函数的使用 例题lanqiao OJ 497成绩分析 第一种用min_element和max_element函数的写法 第二种用min和max的写法 二分查找 二分查找只能对数组操作 binary_s

2024年AMC10美国数学竞赛倒计时两个月:吃透1250道真题和知识点(持续)

根据通知,2024年AMC10美国数学竞赛的报名还有两周,正式比赛还有两个月就要开始了。计划参赛的孩子们要记好时间,认真备考,最后冲刺再提高成绩。 那么如何备考2024年AMC10美国数学竞赛呢?做真题,吃透真题和背后的知识点是备考AMC8、AMC10有效的方法之一。通过做真题,可以帮助孩子找到真实竞赛的感觉,而且更加贴近比赛的内容,可以通过真题查漏补缺,更有针对性的补齐知识的短板。

2024年高教社杯数学建模国赛最后一步——结果检验-事关最终奖项

2024年国赛已经来到了最后一天,有必要去给大家讲解一下,我们不需要过多的去关注模型的结果,因为模型的结果的分值设定项最多不到20分。但是如果大家真的非常关注的话,那有必要给大家讲解一下论文结果相关的问题。很多的论文,上至国赛优秀论文下至不获奖的论文并不是所有的论文都可以进行完整的复现求解,大部分数模论文都为存在一个灰色地带。         白色地带即认为所有的代码均可运行、公开

基于stm32的河流检测系统-单片机毕业设计

文章目录 前言资料获取设计介绍功能介绍具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机设计精品

VB和51单片机串口通信讲解(只针对VB部分)

标记:该篇文章全部搬自如下网址:http://www.crystalradio.cn/thread-321839-1-1.html,谢谢啦            里面关于中文接收的部分,大家可以好好学习下,题主也在研究中................... Commport;设置或返回串口号。 SettingS:以字符串的形式设置或返回串口通信参数。 Portopen:设置或返回串口

【全网最全】2024年数学建模国赛A题30页完整建模文档+17页成品论文+保奖matla代码+可视化图表等(后续会更新)

您的点赞收藏是我继续更新的最大动力! 一定要点击如下的卡片,那是获取资料的入口! 【全网最全】2024年数学建模国赛A题30页完整建模文档+17页成品论文+保奖matla代码+可视化图表等(后续会更新)「首先来看看目前已有的资料,还会不断更新哦~一次购买,后续不会再被收费哦,保证是全网最全资源,随着后续内容更新,价格会上涨,越早购买,价格越低,让大家再也不需要到处买断片资料啦~💰💸👋」�

大厂算法例题解之网易2018秋招笔试真题 (未完)

1、字符串碎片 【题目描述】一个由小写字母组成的字符串可以看成一些同一字母的最大碎片组成的。例如,“aaabbaaac” 是由下面碎片组成的:‘aaa’,‘bb’,‘c’。牛牛现在给定一个字符串,请你帮助计算这个字符串的所有碎片的 平均长度是多少。 输入描述: 输入包括一个字符串 s,字符串 s 的长度 length(1 ≤ length ≤ 50),s 只含小写字母(‘a’-‘z’) 输出描述