本文目录一览:
- 1、如何运用链表实现子弹连续发射 C语言 求代码
- 2、51单片机驱动NRF2401的接受和发射的C语言程序
- 3、单片机程序火箭发射,倒计时和推送都有,用C语言编写
- 4、用C语言编写的红外发射与接收程序
- 5、求一份基于51单片机4X4矩阵键盘红外发射C语言程序,最好附原理图哦!!
如何运用链表实现子弹连续发射 C语言 求代码
includestdio.h#includestdlib.h#includestring.hstruct people{ char name[10]; int age; struct people * next;};int main(){ struct people * head=NULL; struct people * prev , * current; int flag=1; while(flag!=0) { printf("请输入学生姓名,年龄:(年龄输入0结束所有输入工作)\n"); current=(struct people *)malloc(sizeof(struct people)); if(head==NULL) head=current; else prev-next=current; current-next=NULL; scanf("%s",¤t-name); scanf("%d",¤t-age); prev=current; flag=current-age; } printf("Output:\n"); if(head==NULL) printf("无资料。\n"); else { current=head; while(current-next!=NULL) { printf("姓名:%s\n年龄:%d\n\n",current-name,current-age); current=current-next; } }}
51单片机驱动NRF2401的接受和发射的C语言程序
发送#include reg52.h
#includeintrins.h
// 常量定义
#define uchar unsigned char
#define uint unsigned int
#define BYTE_BIT0 0x01
#define BYTE_BIT1 0x02
#define BYTE_BIT2 0x04
#define BYTE_BIT3 0x08
#define BYTE_BIT4 0x10
#define BYTE_BIT5 0x20
#define BYTE_BIT6 0x40
#define BYTE_BIT7 0x80
//---------------------------位变量定义----------------------------------------
bdata uchar DATA_BUF; //用于ByteRead和ByteWrite 函数
#define DATA7 ((DATA_BUFBYTE_BIT7)!=0)
#define DATA0 ((DATA_BUFBYTE_BIT0)!=0)
uchar TxBuf[28]={
0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,
0x09,0x10,0x11,0x12,0x13,0x14,0x15,0x16,
0x17,0x18,0x19,0x20,0x21,0x22,0x23,0x24,
0x25,0x26,0x27,0x28,};// ------------------------------RF2401_Pins 对应引脚 -----------------------
sbit PWR_UP = P1^3;
sbit CE = P1^2;
// sbit DR2 = P1^7; //暂时没有用到
// sbit CLK2 = P1^1;
// sbit OUT2 = P1^6;
sbit CS = P1^0;
sbit DR1 = P1^5;
sbit CLK1 = P1^4;
sbit DATA = P3^3;
//----------------------------------------LED显示端口---------------------------------------------------
sbit LED=P3^5;
//-------------------------------------------------------------------------------
unsigned char TxAddress[4]={0xcc,0xcc,0xcc,0xcc}; //发送地址
//---------------------nRF-Configuration-Register 配置信息 ------------------------------
//芯片测试用,无需修改
#define TEST_2 0x8E // MSB D143-D136
#define TEST_1 0x08 // D135~D128
#define TEST_0 0x1c // D127~D120
// 注意 DATAx_W+ADDRx_W+CRC 的值必须小于256!单个数据包的大小必须小于32字节(256位)
#define DATA2_W 0x10 //未用到--0x10=2字节 //频道2发送/接受数据长度(单位:Bit)
#define DATA1_W 0xE0 //28字节 16 位 //频道1发送/接受数据长度(单位:Bit)
//频道2接收地址 -频道2未使用
#define ADDR2_4 0x00
#define ADDR2_3 0x1c
#define ADDR2_2 0xcc
#define ADDR2_1 0xcc
#define ADDR2_0 0xcc
// 频道1接收地址 (当前模块地址) -只是用频道1
#define ADDR1_4 0x00
#define ADDR1_3 0xcc
#define ADDR1_2 0xcc
#define ADDR1_1 0xcc
#define ADDR1_0 0xcc
//接收地址位置设置--CRC设置
#define ADDR_W 0x10 //0x10 =2字节 //发送/接收地址宽度(单位:Bit)
#define CRC_L 0x1 //CRC模式 0:8位 1:16位
#define CRC_EN 0x1 //CRC校验 0:禁止 1:启用
//频道设置--发送方式设置--速率设置--频率设置
#define RX2_EN 0x0 //双频道功能 0:禁用 1:启用
#define CM 0x1 //0:Direct Mode 1: Shockburst Mode
#define RFDR_SB 0x1 //传输速率 0:250k 1: 1M (250k比1M传输距离远)
#define XO_F 0x3 //16M D12 D11 D10 确定 5种频率
#define RF_PWR 0x3 //信号发射功率---0DB
//
#define RF_CH 0x2 //Channal 频率设置Channel=2400MHz+RF_CH*1.0MHz
#define RXEN 0x0 //0:TX 1:RX
//将设置信息组合成每个字节的数据信息
#define RFconfig_Bit0 TEST_2
#define RFconfig_Bit1 TEST_1
#define RFconfig_Bit2 TEST_0
#define RFconfig_Bit3 DATA2_W
#define RFconfig_Bit4 DATA1_W
#define RFconfig_Bit5 ADDR2_4
#define RFconfig_Bit6 ADDR2_3
#define RFconfig_Bit7 ADDR2_2
#define RFconfig_Bit8 ADDR2_1
#define RFconfig_Bit9 ADDR2_0
#define RFconfig_Bit10 ADDR1_4
#define RFconfig_Bit11 ADDR1_3
#define RFconfig_Bit12 ADDR1_2
#define RFconfig_Bit13 ADDR1_1
#define RFconfig_Bit14 ADDR1_0
#define RFconfig_Bit15 (ADDR_W2|CRC_L1|CRC_EN)
#define RFconfig_Bit16 (RX2_EN7|CM6|RFDR_SB5|XO_F2|RF_PWR)
#define RFconfig_Bit17 (RF_CH1|RXEN)
//通过宏定义将18字节的寄存器参数按照各个功能分解,参照DATASHHET
uchar code nRF2401_Conf[18]=
{
RFconfig_Bit0,RFconfig_Bit1,RFconfig_Bit2,
RFconfig_Bit3,
RFconfig_Bit4,
RFconfig_Bit5,RFconfig_Bit6,RFconfig_Bit7,RFconfig_Bit8,RFconfig_Bit9,
RFconfig_Bit10,RFconfig_Bit11,RFconfig_Bit12,RFconfig_Bit13,RFconfig_Bit14,
RFconfig_Bit15,
RFconfig_Bit16,
RFconfig_Bit17
};
//------------------------------------------函数申明------------------------------------------
void Delay_us(uchar n);
void DoClock();
void Delay_ms(uchar n);
unsigned char Spi_ByteRead(void);
void Spi_ByteWrite(unsigned char send);
void Config2401(void);
void SetTxMode(void);
void nRF2401_TxPacket(uchar TxBuf[]);
//--------------------------------11.0592M晶振 n=100 868us 左右-------------------------------
void Delay_us(uchar n)
{
uint i;
for(i=0;in;i++);
}
//------------------------------------------ -----------------------------------------
void Delay_ms(uchar n)
{
unsigned int i,j,k; for(i=0;in;i++)
{
for(k=0;k5;k++)
{
for(j=0;j200;j++);
}
}
}
/*
//--------------------------SPI读------------------------------------------
unsigned char Spi_ByteRead(void)
{
unsigned char i = 0;
for (i=0; i8; i++)
{
DATA_BUF = DATA_BUF 1;
CLK1 = 1;
DATA = 1; //设置为输入状态
if (DATA) //读取最高位,保存至最末尾,通过左移位完成整个字节
{
DATA_BUF |= BYTE_BIT0;
}
else
{
DATA_BUF = ~BYTE_BIT0;
}
CLK1 = 0;
}
return DATA_BUF;
}*/
//----------------------------------SPI写-----------------------------------------
void Spi_ByteWrite(unsigned char send)
{
unsigned char i; DATA_BUF = send; CLK1 = 0; for (i=0; i8; i++)
{
if (DATA7) //总是发送最高位
{
DATA = 1;
}
else
{
DATA = 0;
}
CLK1 = 1;
DATA_BUF = DATA_BUF 1;
CLK1 = 0;
}
}
//-----------------------------配置2401--------------------------------------------
void Config2401(void)
{
uint i;
uchar variable1;
PWR_UP=1; //上电
CE=0;
CS=1; //使RF2401进入配置方式
Delay_ms(3); //从上电到进入配置模式需要3ms的延时(最少)
for(i=0;i18;i++) //输入3个测试字节15个配置字节共 18Byte
{
variable1=nRF2401_Conf[i];
Spi_ByteWrite(variable1);
}
CS=0; //Disable CS -----standby mode
DATA=0;
Delay_us(100);
}
//--------------------------------设置为发送模式 ----------------------------
void SetTxMode(void)
{
//-------------------------------设置为配置模式----------------------------------
PWR_UP=1; //上电
CE=0;
CS=1; //进入配置模式
Delay_us(100);
DATA=0; //配置寄存器0字节RXEN 设置为0: 发送模式
CLK1=1;
CLK1=0;
//----------------------------设置为 Activemodes(TX)------------------------------
CS=0;
CE=1; //set standby mode
Delay_us(100);
}
//--------------------------------nRF 数据发送函数--------------------------------
void nRF2401_TxPacket()
{
int i;
uchar variable2;
CE=1;
for(i=0;i2;i++) //写入接受地址(按字节对齐)
{
variable2=TxAddress[i];
Spi_ByteWrite(variable2);
}
for(i=0;i(28);i++) //写入接受地址(按字节对齐)
{
variable2=TxBuf[i];
Spi_ByteWrite(variable2);
}
CE=0; //CE配置低使发送有效
Delay_us(100); //时钟信号高电平有效
}
//------------------------------------主函数---------------------------------------
main()
{
Config2401();
while(1)
{
nRF2401_TxPacket();
SetTxMode();
LED=0; Delay_ms(10);LED=1; Delay_ms(10);
}
}
单片机程序火箭发射,倒计时和推送都有,用C语言编写
#include iostream
#include vector
#include algorithm
using namespace std;
int is_right(int a[],int k)
{
int jian_ge=a[1]-a[0];
int count_num=0;
for(int i=0; ia href=";tn=44039180_cprfenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1d9nhndrAnLnAnkmHf3rH0d0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EnH6vnW0vrHcLnjR1nWmYnj6vPs" target="_blank" class="baidu-highlight"k-1/a; i++)
{
if(a[i+1]-a[i]==jian_ge)
{
count_num++;
}
}
return count_num==a href=";tn=44039180_cprfenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1d9nhndrAnLnAnkmHf3rH0d0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EnH6vnW0vrHcLnjR1nWmYnj6vPs" target="_blank" class="baidu-highlight"k-1/a?true:false;
}
int main()
{
int i;
cini;
vector char result;
vector char :: iterator it;
for(int j=1; j=i; j++)
{
int k;
cink;
int a[k];
for(int m=0; mk; m++)
{
cina[m];
}
if(is_right(a,k)==1)
{
result.push_back('Y');
}
else
{
result.push_back('N');
}
}
// reverse(result.begin(),result.end());
for(it=result.begin(); it!=result.end(); it++)
{
cout*itendl;
}
return 0;
}
用C语言编写的红外发射与接收程序
给你一段430单片机遥控器解码的程序吧,也就是接收部分
毕竟世界太现实只能这么帮你
#ifndef _IR_
#define _IR_
char t0,t1,t2;
uchar IR;
void DelayIR()
{
uint i=130;
while(i--);
}
void init_port2(void)
{
P2DIR=~BIT0;
P2SEL=~BIT0;
P2IES|=BIT0;
P2IE|=BIT0;
}
#pragma vector=PORT2_VECTOR
__interrupt void PORT2_ISR(void)
{
char CounterIR;
P2IES=~BIT0;
if(P2IFGBIT0)
{
P2IFG=~BIT0;
}
CounterIR=0;
while(!(P2INBIT0))
{
DelayIR();
CounterIR++;
}
if(CounterIR85)
{
if(CounterIR95)
{
t1++;
for(char k=0;k17;k++)
{
CounterIR=0;
while((P2INBIT0)(CounterIR50))
{
DelayIR();
CounterIR++;
}
CounterIR=0;
while((!(P2INBIT0))(CounterIR10))
{
DelayIR();
CounterIR++;
}
}
for(char j=0;j8;j++)
{
CounterIR=0;
while((P2INBIT0)(CounterIR25))
{
DelayIR();
CounterIR++;
}
IR=1;
if(CounterIR11)
IR|=BIT0;
CounterIR=0;
while((!(P2INBIT0))(CounterIR10))
{
DelayIR();
CounterIR++;
}
}
if((IR!=0xff)(IR!=0x00))
{
if(!(flagdataflag))
{
if(IR==0x22)
{
flag|=runflag;
}
else
{
Tar[0]=Tar[1];
Tar[1]=Tar[2];
Tar[2]=Tar[3];
Tar[3]=Tar[4];
switch (IR)
{
//case 0x22 : flag|=runflag;break;
case 0x68 : Tar[4]=0;flag|=dataflag;break;
case 0x30 : Tar[4]=1;flag|=dataflag;break;
case 0x18 : Tar[4]=2;flag|=dataflag;t2++;break;
case 0x7a : Tar[4]=3;flag|=dataflag;break;
case 0x10 : Tar[4]=4;flag|=dataflag;break;
case 0x38 : Tar[4]=5;flag|=dataflag;break;
case 0x5a : Tar[4]=6;flag|=dataflag;break;
case 0x42 : Tar[4]=7;flag|=dataflag;break;
case 0x4a : Tar[4]=8;flag|=dataflag;break;
case 0x52 : Tar[4]=9;flag|=dataflag;break;
default : break;
}
}
}
}
IR=0;
}
}
for(int m=0;m250;m++)
DelayIR();
P2IES|=BIT0;
}
#endif
请采纳。
求一份基于51单片机4X4矩阵键盘红外发射C语言程序,最好附原理图哦!!
#include "reg52.h"
sbit ir=P2^0;//红外发射管控制脚,使用24M晶振
sbit led = P2^1;
sbit ka=P1^0;
sbit kb=P1^1;
sbit kc=P1^2;
sbit kd=P1^3;
unsigned int count, set_count; //中断计数,设定中断次数
bit irflag,keyflag; //红外发送标志位,按键标志位
unsigned char irsys[]={0x00,0xff};//16位用户码
unsigned char irdata,ircode; //发送的红外数据
//---------------------------------------------------------------------------
void delay(unsigned int a)//延时约1ms,晶振24M ,此处延时不需很精确
{
unsigned char i;
while(--a!=0)
for(i=300;i0;i--); //若是12M晶振i=125
}
//---------------------------------------------------------------------------
void keyscan() // 按键扫描
{
if(ka==0)
{ delay(5);
while(!ka);
keyflag=1;irdata=0x0a;
} //a键按下,则发射数据0x0a
if(kb==0)
{ delay(5);
while(!kb);
keyflag=1;irdata=0x0b;
} //a键按下,则发射数据0x0a
if(kc==0)
{ delay(5);
while(!kc);
keyflag=1;irdata=0x0c;
} //a键按下,则发射数据0x0a
if(kd==0)
{ delay(5);
while(!kd);
keyflag=1;irdata=0x0d;
} //a键按下,则发射数据0x0a
}
//---------------------------------------------------------------------------
void ir_sendbyte() //红外发送一个字节数据
{
unsigned char i;
for(i=0;i8;i++) //发送8位数据
{
set_count=43;//35; //发送编码中的0.56ms高电平 (//后为12M晶振下的数值)
irflag=1; //启动红外发射二极管发射
count=0; //中断计数先清0
TR0=1; //开启定时器0
while(countset_count); //等待发送完
TR0=0; //关闭定时器0
if(ircode0x01) set_count=130;//130; //判断红外编码最低位,若为1则1.69ms的低电平 (//后为12M晶振下的数值)
else set_count=43;//35; //为0则0.565ms的低电平 (//后为12M晶振下的数值)
irflag=0; //低电平则不发射
count=0; //中断计数清0
TR0=1; //开启定时器0
while(countset_count); //等待发送完
TR0=0; //关闭定时器0
ircode=ircode1; //将数据右移,即从低位到高位发送
}
}
//---------------------------------------------------------------------------
void ir_send() //发送红外数据
{
set_count=692;//672; //发送编码中的引导码(9ms高电平+4.5ms低电平) (//后为12M晶振下的数值) tc9012
irflag=1; //启动红外发射二极管发射
count=0; //中断计数清0
TR0=1;
while(countset_count);
TR0=0;
set_count=346;//336; //发送编码中的4.5ms低电平(//后为12M晶振下的数值)
irflag=0; //低电平则不发射
count=0;
TR0=1;
while(countset_count); //等待发送完
TR0=0;
ircode=irsys[0]; //发送16位用户码的前1-8位
ir_sendbyte();
ircode=irsys[1]; //发送16位用户码的前9-16位
ir_sendbyte();
ircode=irdata; //发送8位数据码
ir_sendbyte();
ircode=~irdata; //发送8位数据反码
ir_sendbyte();
set_count=43;//35; //发送编码中的0.56ms高电平 (//后为12M晶振下的数值)
irflag=1;
count=0;
TR0=1;
while(countset_count);
TR0=0;
ir=1;
delay(23); //延时23ms(编码中的23ms低电平)
set_count=692;//670; //发送编码中的引导码(9ms高电平+4.5ms低电平) (//后为12M晶振下的数值)
irflag=1;
count=0;
TR0=1;
while(countset_count);
TR0=0;
set_count=346;//336; //发送编码中的4.5ms低电平(//后为12M晶振下的数值)
irflag=0;
count=0;
TR0=1;
while(countset_count);
TR0=0;
set_count=43;//35; //发送编码中的0.56ms高电平 (//后为12M晶振下的数值)
irflag=1;
count=0;
TR0=1;
while(countset_count);
TR0=0;
ir=1; //发射完了关闭红外发射二极管
}
//---------------------------------------------------------------------------
void timer0_init() //定时器初始化
{
EA=1;
TMOD=0x02; //定时0 8位自动重装模式
ET0=1;
TH0=0xe6;//0xf3; //定时13us,38K红外矩形波,晶振24M (//后为12M晶振下的数值)
TL0=0xe6;
}
//---------------------------------------------------------------------------
void main()
{
timer0_init(); //定时0初始化
count=0; //中断计数先清0
irflag=0; //红外发射标志先置0
while(1)
{
keyscan(); //键值扫描
if(keyflag) //若有按键按下
{
led = 0;
delay(10);
ir_send(); //发送红外编码
delay(500);
keyflag=0; //按键标志清零
delay(100);
}
else
{
led = 1;
}
}
}
//---------------------------------------------------------------------------
void timer0() interrupt 1 //定时器0中断
{
count++;
if(irflag==1) ir=~ir; //有发射标志,则发射38khz的矩形波
else ir=1; //否则不发射,即相当于发射编码中的低电平
}