एफ # - अनुक्रम

अनुक्रम की तरह अनुक्रम भी मूल्यों के एक संग्रह का प्रतिनिधित्व करते हैं। हालांकि, आवश्यकता होने पर अनुक्रम या अनुक्रम अभिव्यक्ति में तत्वों की गणना की जाती है। उनकी गणना एक बार में नहीं की जाती है, और इस कारण से उन्हें अनंत डेटा संरचनाओं का प्रतिनिधित्व करने के लिए उपयोग किया जाता है।

अनुक्रमों को परिभाषित करना

निम्नलिखित सिंटैक्स का उपयोग करके दृश्यों को परिभाषित किया जाता है -

seq { expr }

उदाहरण के लिए,

let seq1 = seq { 1 .. 10 }

अनुक्रम और अनुक्रम अभिव्यक्तियाँ बनाना

सूचियों के समान, आप श्रेणियों और समझ का उपयोग करके अनुक्रम बना सकते हैं।

अनुक्रम अभिव्यक्तियाँ हैं जो आप अनुक्रम बनाने के लिए लिख सकते हैं। ये किए जा सकते हैं -

  • सीमा निर्दिष्ट करके।
  • श्रेणी में वृद्धि या वृद्धि के साथ निर्दिष्ट करके।
  • का उपयोग करके yield मूल्यों का निर्माण करने के लिए कीवर्ड जो अनुक्रम का हिस्सा बन जाता है
  • → ऑपरेटर का उपयोग करके।

निम्नलिखित उदाहरण अवधारणा को प्रदर्शित करते हैं -

उदाहरण 1

(* Sequences *)
let seq1 = seq { 1 .. 10 }

(* ascending order and increment*)
printfn "The Sequence: %A" seq1
let seq2 = seq { 1 .. 5 .. 50 }

(* descending order and decrement*)
printfn "The Sequence: %A" seq2

let seq3 = seq {50 .. -5 .. 0}
printfn "The Sequence: %A" seq3

(* using yield *)
let seq4 = seq { for a in 1 .. 10 do yield a, a*a, a*a*a }
printfn "The Sequence: %A" seq4

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

The Sequence: seq [1; 2; 3; 4; ...]
The Sequence: seq [1; 6; 11; 16; ...]
The Sequence: seq [50; 45; 40; 35; ...]
The Sequence: seq [(1, 1, 1); (2, 4, 8); (3, 9, 27); (4, 16, 64); ...]

उदाहरण 2

निम्नलिखित कार्यक्रम 1 से 50 तक की प्रमुख संख्या छापता है -

(* Recursive isprime function. *)
let isprime n =
   let rec check i =
      i > n/2 || (n % i <> 0 && check (i + 1))
   check 2

let primeIn50 = seq { for n in 1..50 do if isprime n then yield n }
for x in primeIn50 do
   printfn "%d" x

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

1
2
3
5
7
11
13
17
19
23
29
31
37
41
43
47

अनुक्रम पर बुनियादी संचालन

निम्न तालिका अनुक्रम डेटा प्रकार पर बुनियादी संचालन से पता चलता है -

मूल्य विवरण
append: seq <'T> → seq <' T> → seq <'T> दिए गए दो एन्यूमरेशन को एक समवर्ती एन्यूमरेशन के रूप में लपेटता है।
औसत: seq <^ T> → ^ T अनुक्रम में तत्वों का औसत लौटाता है।
औसतन: ('T → ^ U) → seq <' T> → ^ U अनुक्रम के प्रत्येक तत्व में फ़ंक्शन को लागू करके उत्पन्न परिणामों का औसत लौटाता है।
कैश: seq <'T> → seq <' T> एक अनुक्रम देता है जो इनपुट अनुक्रम के कैश्ड संस्करण से मेल खाता है।
कास्ट: IEnumerable → seq <'T> एक शिथिल टाइप प्रणाली को लपेटता है। संग्रह एक अनुक्रम के रूप में अनुक्रम।
चुनें: ('T →' U विकल्प) → seq <'T> → seq <' U> दिए गए फ़ंक्शन को सूची के प्रत्येक तत्व पर लागू करता है। प्रत्येक तत्व के लिए परिणामों में शामिल सूची लौटाएँ जहाँ फ़ंक्शन लौटता हैSome
एकत्र: ('T →' संग्रह) → seq <'T> → seq <' U> दिए गए फ़ंक्शन को अनुक्रम के प्रत्येक तत्व पर लागू करता है और सभी परिणामों को संक्षिप्त करता है।
तुलना करें: ('T →' T → int) → seq <'T> → seq <' T> → int दिए गए तुलनात्मक फ़ंक्शन, तत्व द्वारा तत्व का उपयोग करके दो अनुक्रमों की तुलना करता है।
concat: seq <'Collection> → seq <' T> दिए गए एन्यूमरेशन-ऑफ-एन्यूमरेशन्स को सिंगल कॉन्टेनेटेड एन्यूमरेशन के रूप में जोड़ती है।
countBy: ('T →' की) → seq <'T> → seq <' Key * int> एक अनुक्रम के प्रत्येक तत्व के लिए एक कुंजी-उत्पादक फ़ंक्शन को लागू करता है और एक अनुक्रम देता है जो अद्वितीय अनुक्रम और मूल अनुक्रम में होने वाली घटनाओं की संख्या देता है।
देरी: (इकाई → seq <'T>) → seq <' T> एक अनुक्रम देता है जो किसी अनुक्रम के दिए गए विलंबित विनिर्देश से निर्मित होता है।
अलग: seq <'T> → seq <' T> एक अनुक्रम देता है जिसमें सामान्य हैश और प्रविष्टियों पर समानता की तुलना में कोई डुप्लिकेट प्रविष्टियाँ नहीं होती हैं। यदि कोई तत्व अनुक्रम में कई बार होता है तो बाद की घटनाओं को छोड़ दिया जाता है।
विशिष्ट: ('टी →' कुंजी) → seq <'T> → seq <' T> एक अनुक्रम देता है जिसमें दिए गए कुंजी-जनरेटिंग फ़ंक्शन द्वारा लौटाए गए कुंजी पर सामान्य हैश और समानता की तुलना के अनुसार कोई डुप्लिकेट प्रविष्टियां नहीं हैं। यदि कोई तत्व अनुक्रम में कई बार होता है तो बाद की घटनाओं को छोड़ दिया जाता है।
खाली: seq <'T> एक खाली क्रम बनाता है।
बिल्कुल: seq <'T> →' T अनुक्रम का एकमात्र तत्व देता है।
मौजूद है: ('T → बूल) → seq <' T> → बूल यदि अनुक्रम का कोई तत्व दिए गए विधेय को संतुष्ट करता है तो परीक्षण।
मौजूद 2: ('T1 →' T2 → बूल) → seq <'T1> → seq <' T2 → → बूल यदि टेस्ट सीक्वेंस के संबंधित तत्वों में से कोई भी युग्म दिए गए विधेय को संतुष्ट करता है।
फ़िल्टर: ('T → बूल) → seq <' T> → seq <'T> एक नया संग्रह लौटाता है जिसमें संग्रह के केवल तत्व होते हैं जिसके लिए दिए गए विधेय रिटर्न देता है true
खोजें: ('T → बूल) → seq <' T> → 'T पहला तत्व लौटाता है जिसके लिए दिए गए फ़ंक्शन देता है true
findIndex: ('T → बूल) → seq <' T> → int पहले तत्व का सूचकांक लौटाता है जिसके लिए दिए गए फ़ंक्शन वापस आते हैं true
तह: ('राज्य →' टी → 'राज्य) →' राज्य → seq <'T> →' राज्य संग्रह के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (fs i0) ...) iN गणना करता है।
forall: ('T → बूल) → seq <' T> → बूल यदि अनुक्रम के सभी तत्व दिए गए विधेय को संतुष्ट करते हैं तो टेस्ट करें।
forall2: ('T1 →' T2 → बूल) → seq <'T1> → seq <' T2> → बूल दो अनुक्रमों से खींचे गए तत्वों के सभी युग्म टेस्ट को दिए गए विधेय को संतुष्ट करते हैं। यदि एक अनुक्रम दूसरे से छोटा है, तो लंबे अनुक्रम के शेष तत्वों को अनदेखा किया जाता है।
groupBy: ('T →' की) → seq <'T> → seq <' key * seq <'T >> एक अनुक्रम के प्रत्येक तत्व के लिए एक कुंजी-उत्पादक फ़ंक्शन को लागू करता है और अद्वितीय कुंजियों के अनुक्रम का उत्पादन करता है। प्रत्येक अद्वितीय कुंजी में उन सभी तत्वों का क्रम भी होता है जो इस कुंजी से मेल खाते हैं।
सिर: seq <'T> →' T अनुक्रम का पहला तत्व लौटाता है।
init: int → (int → 'T) → seq <' T> एक नया अनुक्रम उत्पन्न करता है, जब iterated, दिए गए फ़ंक्शन को दिए गए गिनती तक, क्रमिक तत्वों को लौटाता है। फ़ंक्शन को कॉल करने के परिणाम सहेजे नहीं जाते हैं, अर्थात, तत्वों को पुन: उत्पन्न करने के लिए फ़ंक्शन को फिर से लागू किया जाता है। फ़ंक्शन को आइटम के इंडेक्स जनरेट किया जा रहा है।
initInfinite: (int → 'T) → seq <' T> एक नया अनुक्रम उत्पन्न करता है, जो पुनरावृत्त होने पर, दिए गए फ़ंक्शन को कॉल करके क्रमिक तत्वों को लौटाएगा। फ़ंक्शन को कॉल करने के परिणाम सहेजे नहीं जाते हैं, अर्थात, तत्वों को पुनर्जीवित करने के लिए फ़ंक्शन को फिर से लागू किया जाएगा। फ़ंक्शन को आइटम के इंडेक्स जनरेट किया जा रहा है।
isEmpty: seq <'T> → बूल परीक्षण कि क्या किसी अनुक्रम में कोई तत्व हैं।
पुनरावृति: ('T → इकाई) → seq <' T> → इकाई दिए गए फ़ंक्शन को संग्रह के प्रत्येक तत्व पर लागू करता है।
iter2: ('T1 →' T2 → इकाई) → seq <'T1> → seq <' T2> → इकाई दिए गए फ़ंक्शन को एक साथ दो संग्रहों पर लागू करता है। यदि एक अनुक्रम दूसरे से छोटा है, तो लंबे अनुक्रम के शेष तत्वों को अनदेखा किया जाता है।
iteri: (int → 'T → unit) → seq <' T> → इकाई दिए गए फ़ंक्शन को संग्रह के प्रत्येक तत्व पर लागू करता है। फ़ंक्शन के लिए दिया गया पूर्णांक तत्व के सूचकांक को इंगित करता है।
अंतिम: seq <'T> →' T अनुक्रम का अंतिम तत्व लौटाता है।
लंबाई: seq <'T> → int अनुक्रम की लंबाई लौटाता है।
नक्शा: ('T →' U) → seq <'T> → seq <' U> एक नया संग्रह बनाता है जिसके तत्व संग्रह के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करने के परिणाम हैं। दिए गए फ़ंक्शन को लागू किया जाएगा क्योंकि तत्वों को ऑब्जेक्ट से पुनर्प्राप्त एन्यूमरेटर्स पर मूवनेक्स्ट विधि का उपयोग करने की मांग की जाती है।
map2: ('T1 →' T2 → 'U) → seq <' T1> → seq <'T2> → seq <' U> एक नया संग्रह बनाता है जिसके तत्व दिए गए फ़ंक्शन को दो अनुक्रमों से तत्वों के संबंधित जोड़े पर लागू करने के परिणाम हैं। यदि एक इनपुट अनुक्रम दूसरे से छोटा है, तो लंबे अनुक्रम के शेष तत्वों को अनदेखा किया जाता है।
मापी: (int → 'T →' U) → seq <'T> → seq <' U> एक नया संग्रह बनाता है जिसके तत्व संग्रह के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करने के परिणाम हैं। फ़ंक्शन के लिए दिया गया पूर्णांक इंडेक्स तत्व के इंडेक्स (0 से) को इंगित करता है।
अधिकतम: seq <'T> →' T ऑपरेटर्समैक्स का उपयोग करके तुलना में अनुक्रम के सभी तत्वों में से सबसे बड़ा रिटर्न।
maxBy: ('T →' U) → seq <'T> →' T फ़ंक्शन परिणाम पर ऑपरेटर्समैक्स का उपयोग करके तुलना में अनुक्रम के सभी तत्वों में से सबसे बड़ा रिटर्न।
न्यूनतम: seq <'T> →' T Operators.min का उपयोग करते हुए अनुक्रम के सभी तत्वों के निम्नतम को लौटाता है।
minBy: ('T →' U) → seq <'T> →' T फ़ंक्शन परिणाम पर Operators.min का उपयोग करके, अनुक्रम के सभी तत्वों के निम्नतम को लौटाता है।
nth: int → seq <'T> →' T संग्रह में nth तत्व की गणना करता है ।
सरणी: 'T सरणी → seq <' T> अनुक्रम के रूप में दिए गए सरणी को देखें।
सूची: 'टी सूची → seq <' T> अनुक्रम के रूप में दी गई सूची देखें।
जोड़ीदार: seq <'T> → seq <' T * 'T> प्रत्येक तत्व का एक क्रम इनपुट अनुक्रम और उसके पूर्ववर्ती में देता है, पहले तत्व के अपवाद के साथ जो केवल दूसरे तत्व के पूर्ववर्ती के रूप में वापस किया जाता है।
पिक: ('T →' U विकल्प) → seq <'T> →' U दिए गए फ़ंक्शन को क्रमिक तत्वों पर लागू करता है, पहला मान लौटाता है जहां फ़ंक्शन एक रिटर्न देता है Some मूल्य।
आसानी से: seq <'T> → seq <' T> एक नया अनुक्रम ऑब्जेक्ट बनाता है जो दिए गए अनुक्रम ऑब्जेक्ट को दर्शाता है। यह सुनिश्चित करता है कि मूल अनुक्रम को एक प्रकार के कलाकारों द्वारा फिर से खोजा और उत्परिवर्तित नहीं किया जा सकता है। उदाहरण के लिए, यदि किसी सरणी को दिया गया अनुक्रम लौटाया गया है, तो सरणी के तत्व वापस आ जाएंगे, लेकिन आप दिए गए अनुक्रम ऑब्जेक्ट को किसी सरणी में नहीं डाल सकते।
कम करें: ('T →' T → 'T) → seq <' T> → 'T अनुक्रम के प्रत्येक तत्व के लिए एक फ़ंक्शन लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। पहले दो तत्वों को फ़ंक्शन लागू करने से शुरू करें। फिर इस परिणाम को तीसरे तत्व के साथ फ़ंक्शन में फ़ीड करें और इसी तरह। अंतिम परिणाम लौटाएं।
स्कैन: ('राज्य →' टी → 'राज्य) →' राज्य → seq <'T> → seq <' राज्य> Seq.fold की तरह, लेकिन ऑन-डिमांड की गणना करता है और मध्यस्थ और अंतिम परिणामों के अनुक्रम को लौटाता है।
सिंगलटन: 'T → seq <' T> एक क्रम देता है जो केवल एक आइटम देता है।
छोड़ें: int → seq <'T> → seq <' T> एक अनुक्रम देता है जो अंतर्निहित अनुक्रम के तत्वों की एक निर्दिष्ट संख्या को छोड़ देता है और फिर अनुक्रम के शेष तत्वों की पैदावार करता है।
स्किपविले: ('T → बूल) → seq <' T> → seq <'T> एक अनुक्रम लौटाता है, जब पुनरावृत्त, अंतर्निहित अनुक्रम के तत्वों को छोड़ देता है जबकि दिए गए विधेय देता है true, और फिर अनुक्रम के शेष तत्वों की पैदावार करता है।
सॉर्ट: seq <'T> → seq <' T> कुंजियों द्वारा आदेशित एक क्रम देता है।
SortBy: ('T →' की) → seq <'T> → seq <' T> एक अनुक्रम के प्रत्येक तत्व के लिए एक कुंजी-उत्पादक फ़ंक्शन को लागू करता है और कुंजियों द्वारा आदेशित अनुक्रम प्राप्त करता है। ऑपरेटर्स.कॉम द्वारा कार्यान्वित की गई जेनेरिक तुलना का उपयोग करते हुए कुंजियों की तुलना की जाती है।
sum: seq <^ T> → ^ T अनुक्रम में तत्वों का योग लौटाता है।
sumBy अनुक्रम के प्रत्येक तत्व में फ़ंक्शन को लागू करके उत्पन्न परिणामों का योग लौटाता है।
टेक: int → seq <'T> → seq <' T> अनुक्रम के पहले तत्वों को एक निर्दिष्ट गणना तक लौटाता है।
takeWhile: ('T → बूल) → seq <' T> → seq <'T> एक अनुक्रम लौटाता है, जब पुनरावृत्त, अंतर्निहित अनुक्रम के तत्वों की पैदावार देता है जबकि दिए गए विधेय देता है true, और फिर आगे कोई तत्व नहीं देता है।
toArray: seq <'T> →' T [] दिए गए संग्रह से एक सरणी बनाता है।
सूची: seq <'T> →' T सूची दिए गए संग्रह से एक सूची बनाता है।
truncate: int → seq <'T> → seq <' T> एक अनुक्रम लौटाता है कि जब एनुमरेटेड तत्वों की एक निर्दिष्ट संख्या से अधिक नहीं देता है।
tryFind: ('T → bool) → seq <' T> → 'T विकल्प पहला तत्व लौटाता है जिसके लिए दिए गए फ़ंक्शन देता है true, या None यदि ऐसा कोई तत्व मौजूद नहीं है।
tryFindIndex: ('T → बूल) → seq <' T> → int विकल्प अनुक्रम में पहले तत्व का सूचकांक लौटाता है जो दिए गए विधेय को संतुष्ट करता है, या None यदि ऐसा कोई तत्व मौजूद नहीं है।
tryPick: ('T →' U विकल्प) → seq <'T> →' U विकल्प दिए गए फ़ंक्शन को क्रमिक तत्वों पर लागू करता है, पहला मान लौटाता है जहां फ़ंक्शन एक रिटर्न देता है Some मूल्य।
अनकहा: ('राज्य →' T * 'राज्य विकल्प) →' राज्य → seq <'T> एक क्रम देता है जिसमें दिए गए अभिकलन द्वारा उत्पन्न तत्व होते हैं।
जहाँ: ('T → बूल) → seq <' T> → seq <'T> एक नया संग्रह लौटाता है जिसमें संग्रह के केवल तत्व होते हैं जिसके लिए दिए गए विधेय रिटर्न देता है true। Seq.filter का पर्यायवाची।
windowed: int → seq <'T> → seq <' T []> एक अनुक्रम देता है जो इनपुट अनुक्रम से खींचे गए तत्वों की खिड़कियों को फिसलने देता है। प्रत्येक विंडो को एक ताजा सरणी के रूप में लौटाया जाता है।
zip: seq <'T1> → seq <' T2> → seq <'T1 *' T2> दो अनुक्रमों को जोड़ियों की सूची में जोड़ देता है। दो अनुक्रमों की समान लंबाई की आवश्यकता नहीं है - जब एक अनुक्रम समाप्त हो जाता है तो अन्य अनुक्रम में किसी भी शेष तत्वों को अनदेखा किया जाता है।
zip3: seq <'T1> → seq <' T2> → seq <'T3> → seq <' T1 * 'T2 *' T3> तीन अनुक्रमों को त्रिगुणों की सूची में जोड़ता है। अनुक्रम की समान लंबाई की आवश्यकता नहीं है - जब एक अनुक्रम समाप्त हो जाता है तो अन्य अनुक्रमों में किसी भी शेष तत्वों को अनदेखा किया जाता है।

निम्नलिखित उदाहरणों में उपरोक्त कुछ कार्यात्मकताओं के उपयोग प्रदर्शित होते हैं -

उदाहरण 1

यह कार्यक्रम एक खाली अनुक्रम बनाता है और इसे बाद में भरता है -

(* Creating sequences *)
let emptySeq = Seq.empty
let seq1 = Seq.singleton 20

printfn"The singleton sequence:"
printfn "%A " seq1
printfn"The init sequence:"

let seq2 = Seq.init 5 (fun n -> n * 3)
Seq.iter (fun i -> printf "%d " i) seq2
printfn""

(* converting an array to sequence by using cast *)
printfn"The array sequence 1:"
let seq3 = [| 1 .. 10 |] :> seq<int>
Seq.iter (fun i -> printf "%d " i) seq3
printfn""

(* converting an array to sequence by using Seq.ofArray *)
printfn"The array sequence 2:"
let seq4 = [| 2..2.. 20 |] |> Seq.ofArray
Seq.iter (fun i -> printf "%d " i) seq4
printfn""

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

The singleton sequence:
seq [20]
The init sequence:
0 3 6 9 12
The array sequence 1:
1 2 3 4 5 6 7 8 9 10
The array sequence 2:
2 4 6 8 10 12 14 16 18 20

कृपया ध्यान दें कि -

  • Seq.empty विधि एक खाली अनुक्रम बनाता है।

  • Seq.singleton विधि केवल एक निर्दिष्ट तत्व का एक क्रम बनाती है।

  • Seq.init पद्धति एक अनुक्रम बनाती है जिसके लिए दिए गए फ़ंक्शन का उपयोग करके तत्व बनाए जाते हैं।

  • Seq.ofArray और Seq.ofList <'T> तरीके सरणियों और सूचियों से अनुक्रम बनाते हैं।

  • Seq.iter विधि एक अनुक्रम के माध्यम से पुनरावृत्ति की अनुमति देता है।

उदाहरण 2

Seq.unfold पद्धति एक गणना फ़ंक्शन से एक अनुक्रम उत्पन्न करती है जो एक राज्य लेती है और अनुक्रम में प्रत्येक बाद के तत्व का उत्पादन करने के लिए इसे बदल देती है।

निम्नलिखित फ़ंक्शन पहले 20 प्राकृतिक संख्याओं का उत्पादन करता है -

let seq1 = Seq.unfold (fun state -> if (state > 20) then None else Some(state, state + 1)) 0
printfn "The sequence seq1 contains numbers from 0 to 20."
for x in seq1 do printf "%d " x
printfn" "

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

The sequence seq1 contains numbers from 0 to 20.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20

उदाहरण 3

Seq.truncate विधि किसी अन्य अनुक्रम से अनुक्रम बनाती है, लेकिन अनुक्रम को तत्वों की एक निर्दिष्ट संख्या तक सीमित करती है।

Seq.take विधि एक नया अनुक्रम बनाती है जिसमें अनुक्रम की शुरुआत से निर्दिष्ट तत्वों की संख्या होती है।

let mySeq = seq { for i in 1 .. 10 -> 3*i }
let truncatedSeq = Seq.truncate 5 mySeq
let takeSeq = Seq.take 5 mySeq

printfn"The original sequence"
Seq.iter (fun i -> printf "%d " i) mySeq
printfn""

printfn"The truncated sequence"
Seq.iter (fun i -> printf "%d " i) truncatedSeq
printfn""

printfn"The take sequence"
Seq.iter (fun i -> printf "%d " i) takeSeq
printfn""

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

The original sequence
3 6 9 12 15 18 21 24 27 30
The truncated sequence
3 6 9 12 15
The take sequence
3 6 9 12 15