AutoLisp 返回字符串中某一子串首次出现的位置的函数

本文深入探讨了在主字符串中查找子字符串首次出现位置的算法实现。通过详细解释代码逻辑,包括子串长度比较、逐字符对比过程及匹配情况记录,帮助读者理解并掌握这一基础字符串操作技巧。
 1 ;返回字符串中某一子串首次出现的位置
 2 (defun my_strstr(mstr zstr / retu)
 3     (setq mstr_l (strlen mstr) zstr_l (strlen zstr))
 4     (if (<= zstr_l mstr_l)
 5         ;主字符串长度大于或等于子字符长度
 6         (progn 
 7             (setq i 1)
 8             (setq tc_w1 T) ;退出循环时使用
 9             (setq ppqk nil) ;表示匹配情况
10             (while (and tc_w1 (<= i (+ 1 (- mstr_l zstr_l))))
11                 (setq j 1)
12                 (setq tc_w2 T)  ;退出循环时使用
13 
14                 ;对子串的每一个字符逐一比较
15                 (while (and tc_w2 (<= j zstr_l))
16                     (if (= (substr mstr (+ i (- j 1)) 1) (substr zstr j 1))
17                         (setq j (+ j 1))
18                         (setq tc_w2 nil)
19                     
20                     )
21                 )
22                 (if (= j (+ 1 zstr_l))
23                     (progn (setq tc_w1 nil ppqk i))
24                     (setq i (+ 1 i))
25                 )
26             
27             )
28             (setq retu ppqk)
29         
30         )
31         
32         ;否则
33         (setq retu nil)
34     
35     )
36     
37 )
38 
39 
40 (print (strstr "ABCDEFG" "EFG"))

 

转载于:https://www.cnblogs.com/chenjiafeng/p/7583314.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值