Chuyển đến nội dung
Diễn đàn CADViet
  • Thông báo

    • Nguyen Hoanh

      CADViet đã hoàn tất nâng cấp   14/09/2017

      Chào các bạn, CADViet đã hoàn tất việc nâng cấp lên phiên bản mới. Tất cả các chức năng đã hoạt động theo kỳ vọng của ban quản trị. Nếu có vấn đề gì cần phản hồi, các bản post ở đây nhé: Trân trọng, Nguyễn Hoành.
Đăng nhập để thực hiện theo  
dkkx3a

Hỏi Lisp so sánh hai tập hợp!

Các bài được khuyến nghị

dkkx3a    58

Mình viết một lisp so sánh hai tập hợp các dữ liệu

Ví dụ tập hợp các text:

              + Th1 = ("1" "2" "3" "7" "9");

              + Th2 = ("1" "2" "3" "4" "5" "6")

Mình muốn so sánh các phần tử của tập hợp 1 với tập hợp 2, nếu phần tử nào của tập hợp 1 mà không có trong tập hợp 2 thì trả về list danh sách các phần tử của tập hợp 1 không thuộc tập hai"

               (sosanh12 th1 th2) = th12: ("7" "9")

Mình có viết một lệnh mà không chạy được, bác nào hỗ trợ để mình hoàn thiện lisp của mình với. thanks!

 

 

(defun SS12 (ds1 ds2 / index)
(setq index 0)
(while (> (length ds1) index)
  (progn
   (setq ds1_i (nth index ds1))
   (if (= (member ds1_i ds1) nil)
(setq ds12 (cons ds1_i ds12))
); end if
   (setq index (+ index 1))
   );end progn
);end while
  ds12
)
(defun SS12 (ds1 ds2 / index)
(setq index 0)
(while (> (length ds1) index)
  (progn
   (setq ds1_i (nth index ds1))
   (if (= (member ds1_i ds1) nil)
(setq ds12 (cons ds1_i ds12))
); end if
   (setq index (+ index 1))
   );end progn
);end while
  ds12
)
(defun SS12 (ds1 ds2 / index)
(setq index 0)
(while (> (length ds1) index)
  (progn
   (setq ds1_i (nth index ds1))
   (if (= (member ds1_i ds1) nil)
(setq ds12 (cons ds1_i ds12))
); end if
   (setq index (+ index 1))
   );end progn
);end while
  ds12
)
(defun SS12 (ds1 ds2 / index)
(setq index 0)
(while (> (length ds1) index)
  (progn
   (setq ds1_i (nth index ds1))
   (if (= (member ds1_i ds1) nil)
(setq ds12 (cons ds1_i ds12))
); end if
   (setq index (+ index 1))
   );end progn
);end while
  ds12
)
(defun SS12 (ds1 ds2 / index)
(setq index 0)
(while (> (length ds1) index)
  (progn
   (setq ds1_i (nth index ds1))
   (if (= (member ds1_i ds1) nil)
(setq ds12 (cons ds1_i ds12))
); end if
   (setq index (+ index 1))
   );end progn
);end while
  ds12
)

Chia sẻ bài đăng này


Liên kết tới bài đăng
Chia sẻ trên các trang web khác
Tot77    501

Bạn làm như sau:

 

 
(setq Th1 '("1" "2" "3" "7" "9")
      Th2 '("1" "2" "3" "4" "5" "6"))
(vl-remove-if '(lambda(x) (member x Th2)) Th1)
 
(setq Th1 '("1" "2" "3" "7" "9")
      Th2 '("1" "2" "3" "4" "5" "6"))
(vl-remove-if '(lambda(x) (member x Th2)) Th1)
  • Vote tăng 1

Chia sẻ bài đăng này


Liên kết tới bài đăng
Chia sẻ trên các trang web khác
Tue_NV    3.841

Chào dkkx3a!

 (setq ds1_i (nth index ds1))
   (if (= (member ds1_i ds1) nil)

Vì (setq ds1_i (nth index ds1))

nên 

   (if (= (member ds1_i ds1) nil)

;;;;;;

ds1_i bao giờ cũng là "thành viên" của ds1 nên biểu thức logic sau if bao giờ cũng là T

;;;;;;;;;

Hy vọng bạn tự sửa được

  • Vote tăng 1

Chia sẻ bài đăng này


Liên kết tới bài đăng
Chia sẻ trên các trang web khác
hiepttr    523

hoặc là nh­ư­­­ thế này cho dễ ngấm :D :D :D

(defun test(lst_1 lst_2 / lst_12)
(foreach elem lst_1
	(if (not (member elem lst_2)) (setq lst_12 (cons elem lst_12))))
(reverse lst_12)
)
  • Vote tăng 2

Chia sẻ bài đăng này


Liên kết tới bài đăng
Chia sẻ trên các trang web khác

Tạo một tài khoản hoặc đăng nhập để nhận xét

Bạn cần phải là một thành viên để lại một bình luận

Tạo tài khoản

Đăng ký một tài khoản mới trong cộng đồng của chúng tôi. Điều đó dễ mà.

Đăng ký tài khoản mới

Đăng nhập

Bạn có sẵn sàng để tạo một tài khoản ? Đăng nhập tại đây.

Đăng nhập ngay

Đăng nhập để thực hiện theo  

×