OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4234|回复: 1

请高手帮忙解释一下这个二分法是怎么算的

[复制链接]

72

主题

251

帖子

0

精华

高级会员

Rank: 4

积分
597
金钱
597
注册时间
2012-3-29
在线时间
7 小时
发表于 2013-11-15 10:33:00 | 显示全部楼层 |阅读模式
WCHAR ff_convert ( /* Converted code, 0 means conversion error */
 WCHAR src, /* Character code to be converted */
 UINT dir  /* 0: Unicode to OEMCP, 1: OEMCP to Unicode */
)
{
 WCHAR t[2];
 WCHAR c;
 u32 i, li, hi;
 u16 n;   
 u32 gbk2uni_offset=0;   
       
 if (src < 0x80)c = src;//ASCII,直接不用转换.
 else
 {
   if(dir) //GBK 2 UNICODE
  {
   gbk2uni_offset=ftinfo.ugbksize/2; 
  }else //UNICODE 2 GBK 
  {  
   gbk2uni_offset=0; 
  }   
  /* Unicode to OEMCP */
  hi=ftinfo.ugbksize/2;//对半开.
  hi =hi / 4 - 1;
  li = 0;
  for (n = 16; n; n--)
  {
   i = li + (hi - li) / 2; 
   SPI_Flash_Read((u8*)&t,ftinfo.ugbkaddr+i*4+gbk2uni_offset,4);//读出4个字节 
   if (src == t[0]) break;
   if (src > t[0])li = i; 
   else hi = i;   
  }
  c = n ? t[1] : 0;      
 }
 return c;
}    
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-11-15 12:18:17 | 显示全部楼层
就是按二分法找啊,呵呵。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-9 03:01

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表