snigefqb 发表于 2021-4-15 18:09:26

传递字符窜返回颠倒的字符窜,请大家检查有问题没有

;;;带*号的变量为全局变量                                       
;;;-------------------------------------------------------------
;;;                     <<函数名字>>                        
;;;   YY:reverse_string                                       
;;;-------------------------------------------------------------
;;;                         <<说明>>                           
;;;   传递字符窜返回颠倒的字符窜                              
;;;-------------------------------------------------------------
;;;                         <<条件>>                           
;;; (list (list str))                                          
;;; str为字符窜                                                
;;;-------------------------------------------------------------
;;;                           改进方式                        
;;; 检查中文码是否大于127                                       
;;;-------------------------------------------------------------
(defun YY:reverse_string (YY:reverse_string_list /YY:reverse_string_strYY:reverse_string_list YY:reverse_string_list1)
(if (= 1 (length YY:reverse_string_list));判断传递的参数是否为1个
    (if (= 'str (type (setq YY:reverse_string_str (car YY:reverse_string_list))));判断满足条件的的参数类型是否符合子函数的要求
      (progn
(setq YY:reverse_string_list (vl-string->list YY:reverse_string_str));转码 将符号设置为以表形式定义的函数
(whileYY:reverse_string_list
       (if (> (nth 0 YY:reverse_string_list) 127);当中文为大于127的两个码组成
       (progn
         (setq YY:reverse_string_list1 (cons (nth 0 YY:reverse_string_list) (cons (nth 1 YY:reverse_string_list) YY:reverse_string_list1)));中文取两个码
         (setq YY:reverse_string_list (cddr YY:reverse_string_list));
         );end_if->t->end_progn
       (progn
         (setq YY:reverse_string_list1 (cons (nth 0 YY:reverse_string_list) YY:reverse_string_list1));取一码
         (setq YY:reverse_string_list (cdr YY:reverse_string_list))
         );end_if->nil->end_progn
       );end_if
    );end_while
(vl-list->string YY:reverse_string_list1);将一系列与整数表相关联的字符组合成字符串
);end_prong
      );end_if->t->end_if
    (princ "\nYY:reverse_string函数 传递的参数不为1,请检查!");end_if->nil
    );end_if
);end_defun

tryhi 发表于 2021-4-16 11:52:23

本帖最后由 tryhi 于 2021-4-16 15:04 编辑

你这传参是不是有点反人类?另外128好像是有一个很特殊的符号

;;字符串倒置
(defun reverse_string(str / a)
      (setq str(vl-string->list str)a"")
      (while
                (if(<(car str)129)
                        (setq a(strcat(chr(car str))a)str(cdr str))
                        (setq a(strcat(strcat(chr(car str))(chr(cadr str)))a)str(cddr str))))
      a
)

(reverse_string "ab今天的天气vevrgood好")

snigefqb 发表于 2021-4-16 16:02:21

tryhi 发表于 2021-4-16 11:52
你这传参是不是有点反人类?另外128好像是有一个很特殊的符号

;;字符串倒置


参数传递是因为某些需要多个参数的,但是某些参数可以像函数一样省略,个人习惯

e2002 发表于 2021-4-16 17:44:11

2021开始 LISP支持 unicode了,一个中文字也是一个字符长度。
页: [1]
查看完整版本: 传递字符窜返回颠倒的字符窜,请大家检查有问题没有