使用C语言怎么实现一个模糊搜索功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
成都创新互联是专业的大厂网站建设公司,大厂接单;提供网站建设、成都网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行大厂网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
//模糊搜索判断是否符合筛选条件 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若返回值f=1则表示符合筛选条件,即查询对象含有包含关键词的片段。最为关键的循环就是按照子字符串的长度从1到N1(查询对象字符串的长度)。
以下片段为遍历代码,可看可不看,核心算法都在上面。注:博主实现模糊搜索的环境是linux系统下的gtk开发。
//按学号查找界面的<查找> void on_button_idsearch_clicked(GtkObject* widget,gpointer user_data) { int i; int f=0; GtkTreeIter iter; //获取搜索关键字 const gchar* keywords = gtk_entry_get_text(entry_search_id); gtk_list_store_clear(liststore2); for(i=0;iC语言是什么
C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发,使用C语言可以以简易的方式编译、处理低级存储器。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。
新闻标题:使用C语言怎么实现一个模糊搜索功能
分享路径:http://njwzjz.com/article/ihccsg.html