bitmap汉子匹配

 

#include   <stdio.h>
#include  <stdlib.h>
#include  <string.h>

typedef    ushort  wchar;
#define  MAX_WORD_LEN    32 

int  checkbit (char  *p ,int  value)
{
        int idiv=value/8;
        int  imod=value%8;
        return  *(p+idiv)  &  0x1 << imod ;
}
void  setbit(char *p , int  value)
{
        int idiv=value/8;
        int  imod=value%8;
        *(p+idiv) = *(p+idiv)  |  0x1 << imod ;
}

int  is_hotword( char *pbuffer)
{
        char  filename[100]="\0";
        sprintf(filename,"%s/%s",".","hotword.txt");
        char  filenamesearch[100]="\0";
        sprintf(filenamesearch,"%s/%s",".","hotwordsearch.txt");
        static  FILE   *fp=NULL;
        static  FILE   *fpsearch=NULL;
        static  char  hotword[256]="\0";
        if(!fp)
        {
                fp=fopen(filename,"rt");
                char  buffer[256]="\0";

                while (fgets(buffer, sizeof(buffer) - 1, fp) > 0)
                {
                        char *pvalue = (char *)memchr(buffer, '\t', sizeof(buffer));
                        int        ikeylen = (pvalue - buffer) > MAX_WORD_LEN ? MAX_WORD_LEN : (pvalue - buffer);
                        char  tmpword[3]="\0";
                        memcpy(tmpword , buffer ,ikeylen);
                        ushort  value=*(ushort *) tmpword;
                        setbit(pbuffer, value);

                }
                fpsearch=fopen (filenamesearch ,"rt");
                while (fgets(buffer, sizeof(buffer) - 1, fpsearch) > 0)
                {
                        char *pvalue = (char *)memchr(buffer, '\t', sizeof(buffer));
                        int        ikeylen = (pvalue - buffer) > MAX_WORD_LEN ? MAX_WORD_LEN : (pvalue - buffer);
                        char  tmpword[3]="\0";
                        memcpy(tmpword , buffer ,ikeylen);
                        ushort  value=*(ushort *) tmpword;
                        if (  checkbit (pbuffer ,value ) )
                        {
                                printf("find  %s  \n",tmpword);
                        }


                }


        }

 

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值