十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
在数据结构里倒是经常接触key,例如keytype
站在用户的角度思考问题,与客户深入沟通,找到河南网站设计与河南网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都做网站、成都网站制作、企业官网、英文网站、手机端网站、网站推广、域名与空间、虚拟空间、企业邮箱。业务覆盖河南地区。
key,表示的是用户自己定义的变量类型,不过你这个key()可以是你自己定义的一个什么函数吧,如果是一个无参数返回的函数应该是void
key();哎,同感,问的太“简洁”了
#includestdio.h
int fun(int a[],int n,int key)
{i
nt low,mid,high;//low、mid、high是三个索引分别指向数组的下标low=0;//low指向数组a[]的第一个元素,即下表为0的元素
high=n-1;//lhigh指向数组a[]的最一个元素,即下表为n-1的元素,n为数组的长度
while(low=high)//循环终止条件是lowhigh的时候
{
mid=(low+high)/2;//所谓二分查找就在这里,每次都让mid指向数组下标等于low和high之和的一半的元素i
f(keya[mid])//如果a【mid】大于要查找的元素,说明要查找的元素在low和mid之间,这是需要把high重新置为mid-1
(high=mid-1);//这里应该是{},不能使()吧
else if(keya[mid])//这里同理,如果a【mid】小于要查找的元素,说明要查找的元素在mid和high之间,这是需要把low重新置为mid+1
(low=mid+1);
else
return mid;//剩下的就是相等的情况,直接返回mid就是查找到的结果
}
return -1;//执行到这一步就说明,lowhigh,没有找到要查找的元素,返回-1表示没有结果
}
main()
{
int a[10]={1,2,3,4,5,6,7,8,9,10};
int a,b,c;
b=4;
c=fun(a,10,b);
if(c==1)
printf("not found");
else
printf("psition %d\n",c);
}
有具体的上下文吗?起码也要把 key ( )这个函数内容写出来
一般来讲这个可以是一个标识符,表示与其字面一致的意思
Key_dec==0 意思是判断变量是否为0, 为0,表达式为真,否则为假
申明或定义一个名为key的函数该函数没有返回值,只有一个指针参数
#includereg51.h
#includeintrins.h
#includemath.h
#define uchar unsigned char
#define uint unsigned int
#define S_RST DS_RST=1
#define C_RST DS_RST=0
#define S_CLK DS_CLK=1
#define C_CLK DS_CLK=0
#define Write_Disable RW_DS1302(0x8e,0x80) //写保护
#define Write_Enable RW_DS1302(0x8e,0x00) //允许写入
sbit SET = P1^5; //设置按键
sbit ADD = P1^4; //调整加
sbit DEC = P1^6; //调整减
#define RdefineT1 TH1=0;TL1=0;TR1=0;a=0; //初始化超时检测
//#define Delay2us() _nop_();_nop_(); //延时2us,每nop 1us
//#define Delay8us() _nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
#define ReDetectTime 20 //设置重复检测次次数,超出次数则超时
//ds18b20命令
#define SkipROM 0xCC
#define MatchROM 0x55
#define ReadROM 0x33
#define SearchROM 0xF0
#define AlarmSearch 0xEC
#define Convert 0x44 //启动温度转换
#define WriteScr 0x4E
#define ReadScr 0xBE
#define CopyScr 0x48
#define RecallEE 0xB8
#define ReadPower 0xB4
#define md collect_time[0]0x0f
#define mg (collect_time[0]0x70)/16
#define fd collect_time[1]0x0f
#define fg (collect_time[1]0x70)/16
#define sd collect_time[2]0x0f
#define sg (collect_time[2]0x30)/16
sbit DS_RST = P1^2; //DS复位端
sbit DS_CLK = P1^0; //SCLK端
sbit DS_IO = P1^1; //IO端
sbit DS18B20 = P1^3; //温度传感器接口
bit keyboard,flash,STA=1;
uchar choose,a;
uchar collect_time[3]=;//定义变量秒分时
uchar collect_temperature[2] = ;
uchar num[10] = ;
//七段数码管显示的段码
uchar display[8] = ;
void delay(uint i)
{
uint k;
while(i--)
{
for(k=0;k120;k++)
}
}
void Dat_Int(void)//数据初始化
{
P0=0xff;
P1=0xff;
P2=0xff;
choose=0;
flash=1;
}
void Time01_Int(void)
{
TMOD = 0x12; //定时器0为8位自动重载定时采样,定时器1为16位超时检测处理
TCON = 0x00;
TH0 = 0x60;
TL0 = 0x60;
TR0 = 1;
IE = 0x0a; //允许定时器0、1中断
IP = 0x00;
}
/********************************************************
* *
* DS18B20温度传感器程序段 *
* *
********************************************************/
/***********11微秒延时函数**********/
//
void delayus(uint t)
{
for(;t0;t--);
}
/***********18B20复位函数**********/
void ow_reset(void)
{
char presence=1;
while(presence)
{
while(presence)
{
DS18B20 = 1;_nop_();_nop_();
DS18B20 = 0;
delayus(50); // 550us
DS18B20 = 1;
delayus(6); // 66us
presence=DS18B20; // presence=0继续下一步
}
delayus(45); //延时500us
presence = ~DS18B20;
}
DS18B20 = 1;
}
/**********18B20写命令函数*********/
//向 1-WIRE 总线上写一个字节
void write_byte(uchar val)
{
uchar i;
for (i=8; i0; i--) //
{
DS18B20 = 1;_nop_();_nop_();
DS18B20 = 0;_nop_();_nop_();_nop_();_nop_();_nop_();//5us
DS18B20 = val0x01; //最低位移出
delayus(6); //66us
val=val/2; //右移一位
}
DS18B20 = 1;
delayus(1);
}
//
/*********18B20读1个字节函数********/
//从总线上读取一个字节
uchar read_byte(void)
{
uchar i;
uchar value = 0;
for (i=8;i0;i--)
{
DS18B20 = 1;_nop_();_nop_();
value=1;
DS18B20 = 0; //
_nop_();_nop_();_nop_();_nop_(); //4us
DS18B20 = 1;_nop_();_nop_();_nop_();_nop_(); //4us
if(DS18B20)value|=0x80;
delayus(6); //66us
}
DS18B20 = 1;
return(value);
}
//
/***********读出温度函数**********/
//
void Ds18b20_ReadEE(void)
{
ow_reset();
write_byte(SkipROM); // Skip ROM
write_byte(Convert); // 发转换命令
ow_reset(); //总线复位
write_byte(SkipROM); // 发Skip ROM命令
write_byte(ReadScr); // 发读命令
collect_temperature[0]=read_byte(); //温度低8位
collect_temperature[1]=read_byte(); //温度高8位
}
/********************************************************
* *
* DS1302时钟芯片程序段 *
* *
********************************************************/
void DS1302_InputByte(uchar byte) //往DS1302写入1Byte数据
{
uchar i;
uchar temp;
temp = byte;
for(i=8; i0; i--)
{
DS_IO = temp0x01;
S_CLK;
C_CLK;
temp = temp 1;
}
}
uchar DS1302_OutputByte(void) //从DS1302读取1Byte数据
{
uchar i;
uchar temp=0;
for(i=0; i8;i++)
{
C_CLK;
if(DS_IO!=0) temp|=(1i);
S_CLK;
}
return(temp);
}
void RW_DS1302(uchar reg, uchar byte)//向DS1302寄存器写数据
{
C_RST;
C_CLK;
S_RST;
DS1302_InputByte(reg);
DS1302_InputByte(byte);
S_CLK;
C_RST;
}
uchar Read_DS1302(uchar reg)//从DS1302寄存器读数据
{
uchar byte;
C_RST;
C_CLK;
S_RST;
DS1302_InputByte(reg);
byte = DS1302_OutputByte();
S_CLK;
C_RST;
return(byte);
}
void GetTime_DS1302(uchar *ucCurtime) //读取DS1302当前时间
{
ucCurtime[0] = Read_DS1302(0x81);//格式为: 秒 分 时
ucCurtime[1] = Read_DS1302(0x83);
ucCurtime[2] = Read_DS1302(0x85);
}
void Set_Time(uchar *receive) //写时间
{
Write_Enable; //控制命令,允许写操作
RW_DS1302(0x80,receive[0]);
RW_DS1302(0x82,receive[1]);
RW_DS1302(0x84,receive[2]);
Write_Disable; // 控制命令,写保护
}
/********************************************************
* *
* 数码管显示程序段 *
* *
********************************************************/
void deal(void)//送显前的数据处理
{uint timer2;
uint lstemp;
timer2++;
if(STA)
if(flash)//用于闪动效果的控制的
{
display[0] = num[sg];
display[1] = num[sd];
display[2] = num[fg];
display[3] = num[fd];
display[4] = num[mg];
display[5] = num[md];
}
else
{switch(choose)
{
case 1:display[0]=0;break;
case 2:display[1]=0;break;
case 3:display[2]=0;break;
case 4:display[3]=0;break;
case 5:display[4]=0;break;
case 6:display[5]=0;break;
}
}
if(timer2==3000)//间断性获取温度
{
timer2=0;
if(STA)
{TR0=0;
Ds18b20_ReadEE();
TR0=1;
}
}
if(collect_temperature[1]127)
{
collect_temperature[0]=255-collect_temperature[0];
collect_temperature[1]=255-collect_temperature[1];
}
lstemp=((collect_temperature[0])4)|((collect_temperature[1])4);
display[6] = num[(uchar)((lstemp)/10)];
display[7] = num[(uchar)((lstemp)%10)];
}
/********************************************************
* *
* 按键控制程序段 *
* *
********************************************************/
void Scan(void)
{
if(SET==0keyboard==1) //检测设置键有无按下,并进行相应操作
{
if(SET==0keyboard==1)
{ RdefineT1; //超时检测初始化
choose++;
while(SET==0);
if(choose==7)
{TR0=0;
Set_Time(collect_time);
TR0=1;
STA=1; //设置完毕,重新开始采集时间
choose=0;
}
}
}
if(choose) //只有在时间调整时,加减按键才有作用
{
if(ADD==0keyboard==1) //检测加调整键有无按下,并进行相应操作
{
if(ADD==0keyboard==1)
{ RdefineT1; //超时检测初始化a=0
TR0=0;
switch (choose)
{
case 1 :if(sg==2)
collect_time[2] = collect_time[2]0x0f;
else
break;
case 2 :if((sg2)(sd==9))
collect_time[2] = 0x30;
if((sg=2)(sd==3))
collect_time[2] = 0x30;
else
break;
case 3: if(fg==5)
collect_time[1] = 0x0f;
else
break;
case 4: if(fd==9)
collect_time[1] = 0xf0;
else
break;
case 5: if(mg==5)
collect_time[0] = 0x0f;
else
break;
case 6: if(md==9)
collect_time[0] = 0xf0;
else
break;
}
TR0=1;
while(ADD==0);
}
}
if(DEC==0keyboard==1) //检测减调整键有无按下,并进行相应操作
{
if(DEC==0keyboard==1)
{ RdefineT1; //超时检测初始化
TR0=0;
switch (choose)
{
case 1 :if(sg==0)
collect_time[2]=0x20;
else collect_time[2]-=16;
break;
case 2 :if(sg2sd==0)
collect_time[2] |= 0x09;
if(sg==2sd==0)
collect_time[2] |= 0x03;
else collect_time[2]-=1;
break;
case 3 :if(fg==0)
collect_time[1] |= 0x50;
else collect_time[1]-=16;
break;
case 4 :if(fd==0)
collect_time[1] |= 0x09;
else collect_time[1]-=1;
break;
case 5 :if(mg==0)
collect_time[0] |= 0x50;
else collect_time[0]-=16;
break;
case 6 :if(md==0)
collect_time[0] |= 0x09;
else collect_time[0]-=1;
break;
}
TR0=1;
while(DEC==0);
}
}
}
if(choose!=0) //在设置模式下停止采集时间
else
}
/********************************************************
* *
* AT89S51主程序段 *
* *
********************************************************/
void main(void)
{
Time01_Int();
Dat_Int();
EA = 1; //开中断
ow_reset(); // 开机先转换一次
write_byte(0xCC); // Skip ROM
write_byte(0x44); // 发转换命令
delay(100);
Set_Time(collect_time);
delay(10);
while(1)
{
Scan();
deal();
}//while循环的结束
}//main函数的结束
void Time0_seve() interrupt 1 //定时器0中断服务程序
{
uint timer;
uchar i,ktemp;
if((P10x70)0x70) //防抖控制用
keyboard=1;
else keyboard=0;
timer++;
if(timer==800)//控制数码管的闪动效果
{
if(choose !=0)
flash=~flash;
else flash = 1;
timer=0;
}
TR0=0;
ktemp=P0;
if(P0==0xfe)i=1;
else if(P0==0xfd)i=2;
else if(P0==0xfb)i=3;
else if(P0==0xf7)i=4;
else if(P0==0xef)i=5;
else if(P0==0xdf)i=6;
else if(P0==0xbf)i=7;
else if(P0==0x7f)i=0;
else i=1;
ktemp=ktemp*2+1;
if(ktemp==0xff)ktemp=0xfe;
P0=ktemp;
P2=display[i];
TR0=1;
}
void Time1_seve() interrupt 3 //定时器1中断服务程序
{
TR1=0;TH1=0;TL1=0;
a++;
if(a4*ReDetectTime)
{
choose=0;
a=0;
Set_Time(collect_time);
STA=1; //超过按键等待时间,自动写入并开始采集时间
}
}
另外,站长团上有产品团购,便宜有保证
#includestdio.h
void main()
{ int a[10]={9,16,25,32,2,1,29,81,36,21};
int key,low=0,high=10-1,mid,k=-1;
int i,j,t;
printf(" please input:");
scanf("%d",key);
for(i=0;i10;i++)
{for(j=0;j10-i;j++)
C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译。
为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。目前2011年12月8日,国际标准化组织(ISO)和国际电工委员会(IEC)发布的C11标准是C语言的第三个官方标准,也是C语言的最新标准。
起初,C语言没有官方标准。1978年由美国电话电报公司(ATT)贝尔实验室正式发表了C语言。布莱恩·柯林汉(Brian Kernighan) 和 丹尼斯·里奇(Dennis Ritchie) 出版了一本书,名叫《The C Programming Language》。这本书被 C语言开发者们称为KR,很多年来被当作 C语言的非正式的标准说明。人们称这个版本的 C语言为KR C。