स्केल संग्रह - सूची

स्केल सूचियाँ सरणियों के समान हैं, जिसका अर्थ है, एक सूची के सभी तत्वों में एक ही प्रकार है लेकिन दो महत्वपूर्ण अंतर हैं। सबसे पहले, सूचियाँ अपरिवर्तनीय हैं, जिसका अर्थ है कि सूची के तत्वों को असाइनमेंट द्वारा नहीं बदला जा सकता है। दूसरी, सूचियाँ एक लिंक की गई सूची का प्रतिनिधित्व करती हैं जबकि सरणियाँ सपाट हैं।

एक प्रकार की सूची जिसमें टाइप T के तत्व होते हैं, लिखा जाता है List[T]

निम्नलिखित उदाहरण का प्रयास करें, विभिन्न डेटा प्रकारों के लिए यहां कुछ सूचियों को परिभाषित किया गया है।

// List of Strings
val fruit: List[String] = List("apples", "oranges", "pears")
// List of Integers
val nums: List[Int] = List(1, 2, 3, 4)
// Empty List.
val empty: List[Nothing] = List()
// Two dimensional list
val dim: List[List[Int]] = List(
   List(1, 0, 0),
   List(0, 1, 0),
   List(0, 0, 1)
)

सभी सूचियों को दो मौलिक भवन ब्लॉकों, एक पूंछ का उपयोग करके परिभाषित किया जा सकता है Nil तथा ::, जिसका उच्चारण किया जाता है cons। शून्य भी खाली सूची का प्रतिनिधित्व करता है। उपरोक्त सभी सूचियों को निम्नानुसार परिभाषित किया जा सकता है।

// List of Strings
val fruit = "apples" :: ("oranges" :: ("pears" :: Nil))
// List of Integers
val nums = 1 :: (2 :: (3 :: (4 :: Nil)))
// Empty List.
val empty = Nil
// Two dimensional list
val dim = (1 :: (0 :: (0 :: Nil))) ::
   (0 :: (1 :: (0 :: Nil))) ::
   (0 :: (0 :: (1 :: Nil))) :: Nil

सूचियों पर मूल संचालन

सूचियों के सभी संचालन निम्नलिखित तीन विधियों के संदर्भ में व्यक्त किए जा सकते हैं।

अनु क्रमांक तरीके और विवरण
1

head

यह विधि किसी सूची का पहला तत्व लौटाती है।

2

tail

यह विधि पहले को छोड़कर सभी तत्वों से मिलकर एक सूची देती है।

3

isEmpty

यदि सूची खाली है तो यह विधि सही है अन्यथा गलत है।

निम्नलिखित उदाहरण से पता चलता है कि उपरोक्त विधियों का उपयोग कैसे करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      val fruit = "apples" :: ("oranges" :: ("pears" :: Nil))
      val nums = Nil
      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 : List(oranges, pears)
Check if fruit is empty : false
Check if nums is empty : true

संबंधित सूची

आप या तो उपयोग कर सकते हैं ::: ऑपरेटर या List.:::() विधि या List.concat()दो या अधिक सूचियों को जोड़ने की विधि। कृपया नीचे दिए गए उदाहरण देखें -

उदाहरण

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

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

fruit1 ::: fruit2 : List(apples, oranges, pears, mangoes, banana)
fruit1.:::(fruit2) : List(mangoes, banana, apples, oranges, pears)
List.concat(fruit1, fruit2) : List(apples, oranges, pears, mangoes, banana)

यूनिफ़ॉर्म लिस्ट बनाना

आप उपयोग कर सकते हैं List.fill()विधि एक सूची बनाती है जिसमें एक ही तत्व की शून्य या अधिक प्रतियां शामिल होती हैं। निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      val fruit = List.fill(3)("apples") // Repeats apples three times.
      println( "fruit : " + fruit  )
      val num = List.fill(10)(2)         // Repeats 2, 10 times.
      println( "num : " + num  )
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

fruit : List(apples, apples, apples)
num : List(2, 2, 2, 2, 2, 2, 2, 2, 2, 2)

एक कार्य का सारणीकरण

आप एक फ़ंक्शन का उपयोग कर सकते हैं List.tabulate()सूची को सारणीबद्ध करने से पहले सूची के सभी तत्वों पर लागू करने की विधि। इसकी दलीलें केवल List.fill की तरह हैं: पहली तर्क सूची बनाने के लिए सूची के आयाम देती है, और दूसरी सूची के तत्वों का वर्णन करती है। अंतर केवल इतना है कि तत्वों को तय किए जाने के बजाय, उन्हें एक फ़ंक्शन से गणना की जाती है।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      // Creates 5 elements using the given function.
      val squares = List.tabulate(6)(n => n * n)
      println( "squares : " + squares  )
      val mul = List.tabulate( 4,5 )( _ * _ )      
      println( "mul : " + mul  )
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

squares : List(0, 1, 4, 9, 16, 25)
mul : List(List(0, 0, 0, 0, 0), List(0, 1, 2, 3, 4), 
   List(0, 2, 4, 6, 8), List(0, 3, 6, 9, 12))

रिवर्स सूची आदेश

आप उपयोग कर सकते हैं List.reverseसूची के सभी तत्वों को उलटने की विधि। निम्नलिखित उदाहरण उपयोग को दर्शाता है।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      val fruit = "apples" :: ("oranges" :: ("pears" :: Nil))
      println( "Before reverse fruit : " + fruit )
      println( "After reverse fruit : " + fruit.reverse )
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Before reverse fruit : List(apples, oranges, pears)
After reverse fruit : List(pears, oranges, apples)