测试1

代码块:

//模糊搜索判断是否符合筛选条件
int result_mohu(const gchar* key,char* str)
{
   typedef struct
   {
       char son[11];
   }Element;

   int i,j,k=0,l=0,m=0;

   //f=1为符合筛选条件
   int f=0;

 //N1为str的长度 N2为str连续子串的个数
 int N1=0,N2=0;
 N1=strlen(str);
 /*计算连续子串的个数*/
 for(i=1;i<=N1;i++)
   N2+=i;

   /*计算连续子串的个数*/
   //i控制子字符串的长度
   //j控制赋值
   //k控制新的线性结构b的下标
   //l控制子数组的首项在原数组中的位置
   //m控制即将用作赋值的str的下标
   Element *b=malloc(sizeof(Element)*N2);
   for(i=1;i<=N1;i++)
   {
       l=0;
       /*while循环内为给一个子字符串数组赋值*/
       while(1)
           {
           m=l;
           for(j=0;j<i;j++)
           {
               b[k].son[j]=str[m];
               m++;
           }
           l++;
           k++;
           if(m==N1)
               break;
           }
   }

   //挨个比对
   for(i=0;i<N2;i++)
       if(strcmp(key,b[i].son)==0)
       {
            f=1;
            break;
       }
   free(b);
   return f;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容