找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 762|回复: 4

[求助] [求助]:判断字符是否相连

[复制链接]
发表于 2007-12-25 14:10:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
(defun ch1 (a b /  l1 kk k idx nn)
  (setq l1 '()
        k  (strlen b)
        kk (strlen a)
        idx  0
  )
(while (< idx k)
    (if (setq nn (vl-string-search a b idx))
      (setq l1 (cons (list nn a) l1)
            idx (+ kk nn)
      )
      (setq idx (1+ idx))
    )
  )
(reverse  l1)
)
;;;;;;
(ch1 "一" "低压配电一二一一一系统图(一)")
得到((8 "一") (12 "一") (14 "一") (16 "一") (25 "一"))
"一一一"是相连的,想要得到结果为
((8 "一")(12 "一一一")(25 "一"))
怎么写语句或者给思路
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2007-12-25 14:54:56 | 显示全部楼层
有规律就好办。
比如你可以用(StrParse Str "一一一") 分解,再分细,
也可以针对你的规律自己写函数。
从程序的角度,用公用函数是增加写程序的效率,
即使牺牲一点运行的效率也问题不大。


  1. (defun strParse        (Str Delimiter / SearchStr StringLen return n char)
  2. ;;;(StrParse Str Delimiter)  ;Str字符串  Delimiter分隔符
  3. ;;;将具有分隔符的字符串解析为列表,Delimiter可以多字符
  4.   (setq SearchStr Str return '()
  5.         StringLen (strlen SearchStr)
  6.         strlen-d(strlen Delimiter))
  7.   (while (> StringLen 0)
  8.     (setq n 1
  9.           char (substr SearchStr 1 strlen-d))
  10.     (while (and (/= char Delimiter) (/= char ""))
  11.       (setq n (1+ n) char (substr SearchStr n strlen-d))
  12.     )
  13.     (setq return (cons (substr SearchStr 1 (1- n)) return)
  14.           SearchStr (substr SearchStr (+ n strlen-d) StringLen)
  15.           StringLen (strlen SearchStr))
  16.   )(reverse return)
  17. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2007-12-25 16:14:30 | 显示全部楼层
是不是可以
(setq l1 (ch1 "一" "低压配电一二一一一系统图(一)")
     l2 (mapcar 'car l1)
         l3 (mapcar '(lambda (x) (strlen x)) (mapcar 'cadr l1))
)
通过表l2,l3进行计算那
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2007-12-27 13:18:09 | 显示全部楼层
(ch1 "一" "低压配电一二一一一系统图(一)")
得到((8 "一") (12 "一") (14 "一") (16 "一") (25 "一"))

对结果表进一步分析,即可得到。
思路如下:从后往前遍历,如果是前一个加2,则舍弃即可。


  1. (defun TT (LST)
  2.     (setq LST_NEW '()
  3.           I          (car (last LST))
  4.           STR          (cadr (last LST))
  5.     )
  6.     (foreach N (cdr (reverse LST))
  7.         (if (= (car N) (- I (length (vl-string->list (cadr N)))))
  8.             (setq I   (car N)
  9.                   STR (strcat (cadr N) STR)
  10.             )
  11.             (setq LST_NEW (cons (list I STR) LST_NEW)
  12.                   I          (car N)
  13.                   STR          (cadr N)
  14.             )
  15.         )
  16.     )
  17.     (if (/= STR "")
  18.         (setq LST_NEW (cons (list I STR) LST_NEW))
  19.     )
  20.     ;;返回
  21.     LST_NEW
  22. )


[php]
_$ (tt '((8 "一") (12 "一") (14 "一") (16 "一") (25 "一")))
((8 "一") (12 "一一一") (25 "一"))
_$ (tt '((8 "一") (12 "二") (14 "三") (16 "四") (25 "五")))
((8 "一") (12 "二三四") (25 "五"))
_$ (tt '((8 "一") (12 "二") (14 "33") (16 "四") (25 "五")))
((8 "一") (12 "二33四") (25 "五"))
_$
[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2007-12-28 12:51:55 | 显示全部楼层
谢谢,要的就是这个效果.
再谢谢.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-17 00:04 , Processed in 0.226743 second(s), 38 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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