Scala Collections - ชุด

Scala Set คือชุดขององค์ประกอบประเภทเดียวกันที่แตกต่างกันเป็นคู่ ๆ กล่าวอีกนัยหนึ่งชุดคือคอลเล็กชันที่ไม่มีองค์ประกอบซ้ำกัน ชุดมีสองประเภทคือimmutable และ mutable. ความแตกต่างระหว่างวัตถุที่เปลี่ยนแปลงไม่ได้และไม่เปลี่ยนรูปก็คือเมื่อวัตถุไม่เปลี่ยนรูปวัตถุนั้นจะไม่สามารถเปลี่ยนแปลงได้

ตามค่าเริ่มต้น Scala จะใช้ชุดที่ไม่เปลี่ยนรูป หากคุณต้องการใช้ชุดที่เปลี่ยนได้คุณจะต้องนำเข้าscala.collection.mutable.Setคลาสอย่างชัดเจน หากคุณต้องการใช้ทั้งชุดที่ไม่เปลี่ยนรูปและไม่เปลี่ยนรูปในคอลเลคชันเดียวกันคุณสามารถอ้างถึงชุดที่ไม่เปลี่ยนรูปได้ต่อไปว่าSet แต่คุณสามารถอ้างถึงชุดที่เปลี่ยนได้เป็น mutable.Set.

นี่คือวิธีที่คุณสามารถประกาศชุดที่ไม่เปลี่ยนรูปได้ -

ไวยากรณ์

// Empty set of integer type
var s : Set[Int] = Set()
// Set of integer type
var s : Set[Int] = Set(1,3,5,7)

or 

var s = Set(1,3,5,7)

ในขณะที่กำหนดชุดว่างคำอธิบายประกอบประเภทเป็นสิ่งที่จำเป็นเนื่องจากระบบจำเป็นต้องกำหนดชนิดคอนกรีตให้กับตัวแปร

การใช้งานพื้นฐานในชุด

การดำเนินการทั้งหมดในชุดสามารถแสดงในรูปแบบของสามวิธีต่อไปนี้ -

ซีเนียร์ No วิธีการและคำอธิบาย
1

head

วิธีนี้ส่งคืนองค์ประกอบแรกของชุด

2

tail

วิธีนี้ส่งคืนชุดที่ประกอบด้วยองค์ประกอบทั้งหมดยกเว้นรายการแรก

3

isEmpty

เมธอดนี้จะคืนค่า true หากเซตว่างหรือเป็นเท็จ

ลองใช้ตัวอย่างต่อไปนี้แสดงการใช้วิธีการปฏิบัติงานพื้นฐาน -

ตัวอย่าง

object Demo {
   def main(args: Array[String]) {
      val fruit = Set("apples", "oranges", "pears")
      val nums: Set[Int] = Set()
      println( "Head of fruit : " + fruit.head )
      println( "Tail of fruit : " + fruit.tail )
      println( "Check if fruit is empty : " + fruit.isEmpty )
      println( "Check if nums is empty : " + nums.isEmpty )
   }
}

บันทึกโปรแกรมข้างต้นใน Demo.scala. คำสั่งต่อไปนี้ใช้เพื่อคอมไพล์และรันโปรแกรมนี้

คำสั่ง

\>scalac Demo.scala
\>scala Demo

เอาต์พุต

Head of fruit : apples
Tail of fruit : Set(oranges, pears)
Check if fruit is empty : false
Check if nums is empty : true

ชุดเชื่อมต่อ

คุณสามารถใช้อย่างใดอย่างหนึ่ง ++ ตัวดำเนินการหรือ Set.++() วิธีการเชื่อมสองชุดขึ้นไป แต่ในขณะที่เพิ่มชุดจะลบองค์ประกอบที่ซ้ำกัน

ต่อไปนี้เป็นตัวอย่างในการเชื่อมสองชุดเข้าด้วยกัน

ตัวอย่าง

object Demo {
   def main(args: Array[String]) {
      val fruit1 = Set("apples", "oranges", "pears")
      val fruit2 = Set("mangoes", "banana")
      // use two or more sets with ++ as operator
      var fruit = fruit1 ++ fruit2
      println( "fruit1 ++ fruit2 : " + fruit )
      // use two sets with ++ as method
      fruit = fruit1.++(fruit2)
      println( "fruit1.++(fruit2) : " + fruit )
   }
}

บันทึกโปรแกรมข้างต้นใน Demo.scala. คำสั่งต่อไปนี้ใช้เพื่อคอมไพล์และรันโปรแกรมนี้

คำสั่ง

\>scalac Demo.scala
\>scala Demo

เอาต์พุต

fruit1 ++ fruit2 : Set(banana, apples, mangoes, pears, oranges)
fruit1.++(fruit2) : Set(banana, apples, mangoes, pears, oranges)

ค้นหา Max, Min Elements ในชุด

คุณสามารถใช้ได้ Set.min วิธีค้นหาขั้นต่ำและ Set.maxวิธีค้นหาองค์ประกอบสูงสุดที่มีอยู่ในชุด ต่อไปนี้เป็นตัวอย่างเพื่อแสดงโปรแกรม

ตัวอย่าง

object Demo {
   def main(args: Array[String]) {
      val num = Set(5,6,9,20,30,45)
      // find min and max of the elements
      println( "Min element in Set(5,6,9,20,30,45) : " + num.min )
      println( "Max element in Set(5,6,9,20,30,45) : " + num.max )
   }
}

บันทึกโปรแกรมข้างต้นใน Demo.scala. คำสั่งต่อไปนี้ใช้เพื่อคอมไพล์และรันโปรแกรมนี้

คำสั่ง

\>scalac Demo.scala
\>scala Demo

เอาต์พุต

Min element in Set(5,6,9,20,30,45) : 5
Max element in Set(5,6,9,20,30,45) : 45

ค้นหาค่านิยมทั่วไป Insets

คุณสามารถใช้อย่างใดอย่างหนึ่ง Set.& วิธีการหรือ Set.intersectวิธีการหาค่าร่วมระหว่างสองชุด ลองใช้ตัวอย่างต่อไปนี้เพื่อแสดงการใช้งาน

ตัวอย่าง

object Demo {
   def main(args: Array[String]) {
      val num1 = Set(5,6,9,20,30,45)
      val num2 = Set(50,60,9,20,35,55)
      // find common elements between two sets
      println( "num1.&(num2) : " + num1.&(num2) )
      println( "num1.intersect(num2) : " + num1.intersect(num2) )
   }
}

บันทึกโปรแกรมข้างต้นใน Demo.scala. คำสั่งต่อไปนี้ใช้เพื่อคอมไพล์และรันโปรแกรมนี้

คำสั่ง

\>scalac Demo.scala
\>scala Demo

เอาต์พุต

num1.&(num2) : Set(20, 9)
num1.intersect(num2) : Set(20, 9)