एफ # - Arrays

Arrays निश्चित-आकार, शून्य-आधारित, निरंतर डेटा तत्वों के परस्पर संग्रह हैं जो सभी एक ही प्रकार के हैं।

ऐरे बनाना

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

कार्यों के बिना सरणियों के निर्माण के तीन वाक्यात्मक तरीके हैं -

  • [| और |] और अर्धविराम द्वारा अलग किया गया।
  • प्रत्येक तत्व को एक अलग लाइन पर रखकर, जिस स्थिति में अर्धविराम विभाजक वैकल्पिक है।
  • अनुक्रम अभिव्यक्तियों का उपयोग करके।

आप एक बिंदु ऑपरेटर (।) और कोष्ठक ([और]) का उपयोग करके सरणी तत्वों तक पहुँच सकते हैं।

निम्न उदाहरण सरणियों का निर्माण दर्शाता है -

//using semicolon separator
let array1 = [| 1; 2; 3; 4; 5; 6 |]
for i in 0 .. array1.Length - 1 do
   printf "%d " array1.[i]
printfn" "

// without semicolon separator
let array2 =
   [|
      1
      2
      3
      4
      5
   |]
for i in 0 .. array2.Length - 1 do
   printf "%d " array2.[i]
printfn" "

//using sequence
let array3 = [| for i in 1 .. 10 -> i * i |]
for i in 0 .. array3.Length - 1 do
   printf "%d " array3.[i]
printfn" "

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

1 2 3 4 5 6
1 2 3 4 5
1 4 9 16 25 36 49 64 81 100

बुनियादी संचालन

लाइब्रेरी मॉड्यूल Microsoft.FSharp.Collections.Array एक आयामी सरणियों पर संचालन का समर्थन करता है।

निम्न तालिका Arrays पर मूल संचालन को दर्शाती है -

मूल्य विवरण
परिशिष्ट: 'टी [] →' टी [] → 'टी [] एक सरणी बनाता है जिसमें एक सरणी के तत्व होते हैं और उसके बाद दूसरे सरणी के तत्व होते हैं।
औसत: ^ टी [] → ^ टी किसी सरणी में तत्वों का औसत लौटाता है।
औसतन: ('T → ^ U) →' T [] → ^ U किसी सरणी के प्रत्येक तत्व में फ़ंक्शन को लागू करने से उत्पन्न तत्वों का औसत लौटाता है।
blit: 'T [] → int →' T [] → int → int → इकाई एक सरणी से कई तत्वों को पढ़ता है और उन्हें दूसरे में लिखता है।
चुनें: ('T → U विकल्प) →' T [] → 'U [] किसी सरणी के प्रत्येक तत्व के लिए एक दिया गया फ़ंक्शन लागू करता है। एक एरे को लौटाता है जिसमें प्रत्येक तत्व के लिए परिणाम x होता है जिसके लिए फ़ंक्शन कुछ (x) देता है।
एकत्र: ('T →' U []] → T [] → 'U [] किसी सरणी के प्रत्येक तत्व को दिए गए फ़ंक्शन को लागू करता है, परिणामों को संक्षिप्त करता है, और संयुक्त सरणी देता है।
कॉन्कैट: seq <'T []> →' T [] एक सरणी बनाता है जिसमें एरे के दिए गए प्रत्येक अनुक्रम के तत्व होते हैं।
कॉपी: 'टी →' टी [] एक ऐसा सरणी बनाता है जिसमें आपूर्ति किए गए सरणी के तत्व होते हैं।
बनाएँ: int → 'T →' T [] एक ऐसा ऐरे बनाता है जिसके सभी तत्व शुरू में आपूर्ति मूल्य हैं।
खाली: 'टी [] दिए गए प्रकार के खाली सरणी देता है।
मौजूद है: ('टी → बूल) →' टी [] → बूल परीक्षण कि क्या किसी सरणी का कोई तत्व प्रदत्त विधेय को संतुष्ट करता है।
मौजूद 2: ('T1 →' T2 → बूल) → 'T1 [] →' T2 [] → बूल टेस्ट कि क्या दो सरणियों के संगत तत्वों की कोई भी जोड़ी आपूर्ति की स्थिति को संतुष्ट करती है।
भरें: 'T [] → int → int →' T → इकाई आपूर्ति की गई मान के साथ किसी सरणी के तत्वों की एक श्रृंखला को भरता है।
फ़िल्टर: ('टी → बूल) →' टी [] → 'टी [] एक संग्रह लौटाता है जिसमें केवल दिए गए सरणी के तत्व होते हैं जिसके लिए आपूर्ति की गई स्थिति वापस आती है true
खोजें: ('टी → बूल) →' टी [] → 'टी पहला तत्व लौटाता है जिसके लिए आपूर्ति की गई फ़ंक्शन देता है true। यदि ऐसा कोई तत्व मौजूद नहीं है, तो KeyNotFoundException उठाती है।
findIndex: ('टी → बूल) →' टी [] → इंट एक सरणी में पहले तत्व के सूचकांक को लौटाता है जो आपूर्ति की स्थिति को संतुष्ट करता है। यदि तत्व में से कोई भी स्थिति को संतुष्ट नहीं करता है, तो KeyNotFoundException को उठाएं
तह: ('राज्य →' टी → 'राज्य) →' राज्य → 'टी [] →' राज्य एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन को लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और सरणी तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (fs i0) ...) iN की गणना करता है।
fold2: ('State →' T1 → 'T2 →' State) → 'State →' T1 [] → 'T2 [] →' State दो आपूर्ति किए गए सरणियों से तत्वों के जोड़े के लिए एक फ़ंक्शन लागू करता है, बाएं से दाएं, एक संचयकर्ता तर्क को संगणना के माध्यम से फैलाना। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
foldBack: ('T →' State → 'State) →' T [] → 'State →' State एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन को लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और सरणी तत्व i0 ... iN हैं, तो यह फ़ंक्शन f i0 (... (f iN s)) की गणना करता है।
foldBack2: ('T1 →' T2 → 'राज्य →' राज्य) → 'T1 [] →' T2 [] → 'राज्य →' राज्य दो आपूर्ति किए गए सरणियों से तत्वों के जोड़े पर एक फ़ंक्शन लागू करता है, दाएं-से-बाएं, संगणना के माध्यम से एक संचायक तर्क को फैलाता है। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
forall: ('टी → बूल) →' टी [] → बूल किसी सरणी के सभी तत्व आपूर्ति की स्थिति को संतुष्ट करते हैं या नहीं।
forall2: ('T1 →' T2 → बूल) → 'T1 [] →' T2 [] → बूल टेस्ट कि क्या दो आपूर्ति की सरणियों के सभी संबंधित तत्व एक आपूर्ति की स्थिति को संतुष्ट करते हैं।
प्राप्त करें: 'T [] → int →' T एक सरणी से एक तत्व हो जाता है।
init: int → (int → 'T) →' T [] आपूर्ति की गई आयाम की एक सरणी बनाने के लिए एक आपूर्ति फ़ंक्शन का उपयोग करता है।
isEmpty: 'T [] → बूल परीक्षण कि क्या किसी सरणी में कोई तत्व हैं।
पुनरावृति: ('T → इकाई) →' T [] → इकाई किसी सरणी के प्रत्येक तत्व को दिया गया फ़ंक्शन लागू करता है।
iter2: ('T1 →' T2 → इकाई) → 'T1 [] →' T2 [] → इकाई) दो सरणियों में मिलान अनुक्रमित से तत्वों की एक जोड़ी के लिए आपूर्ति की गई फ़ंक्शन को लागू करता है। दो सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
इतरी: (int → 'T → इकाई) →' T [] → इकाई किसी सरणी के प्रत्येक तत्व को दिया गया फ़ंक्शन लागू करता है। फ़ंक्शन के लिए दिया गया पूर्णांक तत्व के सूचकांक को इंगित करता है।
iteri2: (int → 'T1 →' T2 → इकाई) → 'T1 [] →' T2 [] → इकाई दो सरणियों में मिलान अनुक्रमित से तत्वों की एक जोड़ी के लिए आपूर्ति की गई फ़ंक्शन को लागू करता है, तत्वों के सूचकांक को भी पारित करता है। दो सरणियों की लंबाई समान होनी चाहिए; अन्यथा, एक ArgumentException उठाया जाता है।
लंबाई: 'टी [] → इंट किसी सरणी की लंबाई देता है। लंबाई संपत्ति एक ही काम करती है।
नक्शा: ('T →' U) → 'T [] →' U [] एक ऐसा ऐरे बनाता है जिसके तत्व सप्लाई किए गए ऐरे के प्रत्येक एलीमेंट में दिए गए फंक्शन को लागू करने के परिणाम हैं।
map2: ('T1 →' T2 → 'U) →' T1 [] → 'T2 [] →' U] एक सरणी बनाता है जिसके तत्व आपूर्ति किए गए फ़ंक्शन को दो आपूर्ति किए गए सरणियों के संबंधित तत्वों पर लागू करने के परिणाम हैं। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
मेपी: (int → 'T →' U) → 'T [] →' U [] एक ऐसा ऐरे बनाता है जिसके तत्व सप्लाई किए गए ऐरे के प्रत्येक एलीमेंट में दिए गए फंक्शन को लागू करने के परिणाम हैं। फ़ंक्शन के लिए दिया गया एक पूर्णांक सूचकांक तत्व के सूचकांक को रूपांतरित होने का संकेत देता है।
mapi2: (int → 'T1 →' T2 → 'U) →' T1 [] → 'T2 [] →' U [] एक ऐसा ऐरे बनाता है जिसके तत्व दो संग्रह युग्मों के संगत तत्वों को आपूर्ति किए गए फ़ंक्शन को लागू करने के परिणाम होते हैं, तत्वों के सूचकांक को भी पास करते हैं। दो इनपुट सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
अधिकतम: 'टी [] →' टी किसी सरणी के सभी तत्वों में से सबसे बड़ा देता है। ऑपरेटर्स.max का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
maxBy: ('T →' U) → 'T [] →' T फ़ंक्शन परिणाम पर Operators.max के माध्यम से तुलना करके किसी सरणी के सभी तत्वों का सबसे बड़ा रिटर्न देता है।
मिनट: ('टी [] →' टी) किसी सरणी के सभी तत्वों में से सबसे छोटा लौटाता है। Operators.min का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
minBy: ('T →' U) → 'T [] →' T किसी सरणी के सभी तत्वों में से सबसे छोटा लौटाता है। Operators.min का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
सूची: 'टी सूची →' टी [] आपूर्ति की गई सूची से एक सरणी बनाता है।
ofSeq: seq <'T> →' T [] आपूर्ति की गई असंख्य वस्तु से एक सरणी बनाता है।
विभाजन: ('टी → बूल) →' टी [] → 'टी [] *' टी [] किसी सरणी को दो सरणियों में विभाजित करता है, जिसमें एक तत्व होता है जिसके लिए आपूर्ति की गई स्थिति वापस आती है true, और दूसरा जिनके लिए यह वापस आता है false
परमिट: (इंट → इंट) → 'टी [] →' टी [] निर्दिष्ट क्रमपरिवर्तन के अनुसार किसी सरणी के तत्वों को अनुमति देता है।
पिक: ('टी →' यू विकल्प) → 'टी [] →' यू किसी दिए गए सरणी के क्रमिक तत्वों के लिए आपूर्ति किए गए फ़ंक्शन को लागू करता है, पहला परिणाम लौटाता है जहां फ़ंक्शन कुछ x के लिए कुछ (x) देता है। यदि फ़ंक्शन कुछ (x) को कभी नहीं लौटाता है, तो KeyNotFoundException को उठाया जाता है।
कम करें: ('T →' T → 'T) →' T [] → 'T एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन को लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और सरणी तत्व i0 ... iN हैं, तो यह फ़ंक्शन f (... (f i0 i1) ...) iN गणना करता है। यदि सरणी का आकार शून्य है, तो ArgumentException उठाई गई है।
कम करें: ('T →' T → 'T) →' T [] → 'T एक सरणी के प्रत्येक तत्व के लिए एक फ़ंक्शन को लागू करता है, गणना के माध्यम से एक संचायक तर्क को फैलाता है। यदि इनपुट फ़ंक्शन f है और तत्व i0 ... iN हैं, तो यह फ़ंक्शन f i0 (... (f iN-1 iN)) की गणना करता है। यदि सरणी का आकार शून्य है, तो ArgumentException उठाई गई है।
Rev: 'T [] →' T [] एक प्रदत्त सारणी में तत्वों के क्रम को उलट देता है।
स्कैन: ('राज्य →' टी → 'राज्य) →' राज्य → 'टी [] →' राज्य []) गुना की तरह व्यवहार करता है, लेकिन अंतिम परिणामों के साथ मध्यवर्ती परिणाम लौटाता है।
स्कैनबैक: ('T →' राज्य → 'राज्य) →' T [] → 'राज्य →' राज्य [] फोल्डबैक की तरह व्यवहार करता है, लेकिन अंतिम परिणामों के साथ एक साथ मध्यस्थ परिणाम देता है।
सेट: 'T [] → int →' T → यूनिट एक सरणी का एक तत्व सेट करता है।
सॉर्ट: 'टी [] →' टी [] किसी सरणी के तत्वों को सॉर्ट करता है और एक नया एरे देता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
SortBy: ('T →' की) → 'T [] →' T [] किसी फ़ंक्शन के तत्वों को उस प्रकार में परिवर्तित करने के लिए आपूर्ति की गई फ़ंक्शन का उपयोग करके सॉर्ट करता है जिस पर सॉर्ट ऑपरेशन आधारित है, और एक नया एरे देता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
SortInPlace: 'टी [] → इकाई आपूर्ति की तुलना फ़ंक्शन का उपयोग करके, जगह में सरणी को बदलकर एक सरणी के तत्वों को सॉर्ट करता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
sortInPlaceBy: ('T →' की) → 'T [] → यूनिट कुंजियों के लिए आपूर्ति किए गए प्रक्षेपण का उपयोग करके, जगह में सरणी को बदलकर एक सरणी के तत्वों को सॉर्ट करता है। Operators.compare का उपयोग तत्वों की तुलना करने के लिए किया जाता है।
sortInPlaceWith: ('T →' T → int) → 'T [] → इकाई सरणी में स्थान बदलने के लिए आपूर्ति की तुलना फ़ंक्शन का उपयोग करके एक सरणी के तत्वों को सॉर्ट करता है।
क्रमबद्ध करें: ('T →' T → int) → 'T [] →' T [] आपूर्ति की तुलना फ़ंक्शन का उपयोग करके एक सरणी के तत्वों को सॉर्ट करता है, और एक नया सरणी देता है।
उप: 'T [] → int → int →' T [] एक ऐसा सरणी बनाता है जिसमें आपूर्ति की गई व्यवस्था होती है, जो कि सूचकांक और लंबाई को शुरू करके निर्दिष्ट होती है।
योग: 'टी [] → ^ टी सरणी में तत्वों का योग लौटाता है।
sumBy: ('T → ^ U) →' T [] → ^ U किसी सरणी के प्रत्येक तत्व पर एक फ़ंक्शन लागू करके उत्पन्न परिणामों का योग लौटाता है।
सूची: 'टी [] →' टी सूची आपूर्ति की गई सरणी को एक सूची में परिवर्तित करता है।
toSeq: 'T [] → seq <' T> एक अनुक्रम के रूप में आपूर्ति की गई सरणी का दृश्य।
tryFind: ('T → बूल) →' T [] → 'T विकल्प आपूर्ति की गई सरणी में पहला तत्व देता है जिसके लिए आपूर्ति की गई फ़ंक्शन देता है true। रिटर्नNone यदि ऐसा कोई तत्व मौजूद नहीं है।
tryFindIndex: ('T → बूल) →' T [] → int विकल्प एक सरणी में पहले तत्व के सूचकांक को लौटाता है जो आपूर्ति की स्थिति को संतुष्ट करता है।
tryPick: ('T →' U विकल्प) → 'T [] →' U विकल्प आपूर्ति की गई फ़ंक्शन को दिए गए सरणी के क्रमिक तत्वों पर लागू होता है, और पहला परिणाम देता है जहां फ़ंक्शन कुछ x के लिए कुछ (x) देता है। यदि फ़ंक्शन कुछ वापस नहीं करता है (x),None वापस आ गया है।
अनज़िप: ('T1 *' T2) [] → 'T1 [] *' T2 [] दो सारणियों के टपल में टपल जोड़े की एक सरणी को विभाजित करता है।
unzip3: ('T1 *' T2 * 'T3) [] →' T1 [] * 'T2 [] *' T3 [] तीन सरणियों के एक टपल में तीन तत्वों के tuples की एक सरणी को विभाजित करता है।
zeroCreate: int → 'T [] एक ऐसा ऐरे बनाता है जिसके तत्व शुरू में तयशुदा मान पर अनचेक किए जाते हैं ।defaultof <'T>।
zip: 'T1 [] →' T2 [] → ('T1 *' T2) [] दो सरणियों को एक ऐसे ट्यूपल्स की एक सरणी में मिलाता है जिसमें दो तत्व होते हैं। दो सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।
zip3: 'T1 [] →' T2 [] → 'T3 [] → ((T1 *' T2 * 113 'T3) [] तीन सरणियों को एक सारणी में मिलाता है जिसमें तीन तत्व होते हैं। तीन सरणियों की लंबाई समान होनी चाहिए; अन्यथा, ArgumentException उठाई गई है।

निम्नलिखित अनुभाग में, हम इनमें से कुछ कार्यात्मकताओं के उपयोग देखेंगे।

क्रियाओं का उपयोग करके ऐरे बनाना

ऐरे मॉड्यूल कई कार्य प्रदान करता है जो खरोंच से एक सरणी बनाते हैं।

  • Array.empty फ़ंक्शन एक नया खाली सरणी बनाता है।

  • Array.create फ़ंक्शन एक निर्दिष्ट आकार की एक सरणी बनाता है और दिए गए मानों के लिए सभी तत्वों को सेट करता है।

  • Array.init फ़ंक्शन एक सरणी बनाता है, तत्वों को उत्पन्न करने के लिए एक आयाम और एक फ़ंक्शन दिया जाता है।

  • Array.zeroCreate फ़ंक्शन एक सरणी बनाता है जिसमें सभी तत्व शून्य मान के लिए आरंभीकृत होते हैं।

  • Array.copy फ़ंक्शन एक नया सरणी बनाता है जिसमें ऐसे तत्व होते हैं जो मौजूदा सरणी से कॉपी किए जाते हैं।

  • Array.sub फंक्शन एक अरेंज के एक अरेंज से एक नया एरे बनाता है।

  • Array.append फ़ंक्शन दो मौजूदा सरणियों के संयोजन से एक नया सरणी बनाता है।

  • Array.choose फ़ंक्शन एक नए सरणी में शामिल करने के लिए किसी सरणी के तत्वों का चयन करता है।

  • Array.collect फ़ंक्शन मौजूदा सरणी के प्रत्येक सरणी तत्व पर एक निर्दिष्ट फ़ंक्शन चलाता है और फिर फ़ंक्शन द्वारा उत्पन्न तत्वों को एकत्र करता है और उन्हें एक नए सरणी में जोड़ता है।

  • Array.concat फ़ंक्शन सरणियों का एक क्रम लेता है और उन्हें एक एकल सरणी में जोड़ता है।

  • Array.filter फ़ंक्शन एक बूलियन स्थिति फ़ंक्शन लेता है और एक नया सरणी बनाता है जिसमें इनपुट सरणी से केवल वे तत्व शामिल होते हैं जिनके लिए स्थिति सही है।

  • Array.rev फ़ंक्शन किसी मौजूदा सरणी के क्रम को उल्टा करके एक नया सरणी बनाता है।

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

उदाहरण 1

(* using create and set *)
let array1 = Array.create 10 ""
for i in 0 .. array1.Length - 1 do
   Array.set array1 i (i.ToString())
for i in 0 .. array1.Length - 1 do
   printf "%s " (Array.get array1 i)
printfn " "

(* empty array *)
let array2 = Array.empty
printfn "Length of empty array: %d" array2.Length

let array3 = Array.create 10 7.0
printfn "Float Array: %A" array3

(* using the init and zeroCreate *)
let array4 = Array.init 10 (fun index -> index * index)
printfn "Array of squares: %A" array4

let array5 : float array = Array.zeroCreate 10
let (myZeroArray : float array) = Array.zeroCreate 10
printfn "Float Array: %A" array5

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

0 1 2 3 4 5 6 7 8 9
Length of empty array: 0
Float Array: [|7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0; 7.0|]
Array of squares: [|0; 1; 4; 9; 16; 25; 36; 49; 64; 81|]
Float Array: [|0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0|]

उदाहरण 2

(* creating subarray from element 5 *)
(* containing 15 elements thereon *)

let array1 = [| 0 .. 50 |]
let array2 = Array.sub array1 5 15
printfn "Sub Array:"
printfn "%A" array2

(* appending two arrays *)
let array3 = [| 1; 2; 3; 4|]
let array4 = [| 5 .. 9 |]
printfn "Appended Array:"
let array5 = Array.append array3 array4
printfn "%A" array5

(* using the Choose function *)
let array6 = [| 1 .. 20 |]
let array7 = Array.choose (fun elem -> if elem % 3 = 0 then
   Some(float (elem))
      else
   None) array6

printfn "Array with Chosen elements:"
printfn "%A" array7

(*using the Collect function *)
let array8 = [| 2 .. 5 |]
let array9 = Array.collect (fun elem -> [| 0 .. elem - 1 |]) array8
printfn "Array with collected elements:"
printfn "%A" array9

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

Sub Array:
[|5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15; 16; 17; 18; 19|]
Appended Array:
[|1; 2; 3; 4; 5; 6; 7; 8; 9|]
Array with Chosen elements:
[|3.0; 6.0; 9.0; 12.0; 15.0; 18.0|]
Array with collected elements:
[|0; 1; 0; 1; 2; 0; 1; 2; 3; 0; 1; 2; 3; 4|]

Arrays खोजना

Array.find फ़ंक्शन एक बूलियन फ़ंक्शन लेता है और पहला तत्व देता है जिसके लिए फ़ंक्शन सही लौटाता है, अन्यथा KeyNotFoundException उठाता है।

Array.findIndex फ़ंक्शन समान रूप से काम करता है सिवाय इसके कि वह तत्व के बजाय तत्व के सूचकांक को वापस करता है।

निम्न उदाहरण यह प्रदर्शित करता है।

Microsoft यह दिलचस्प कार्यक्रम उदाहरण प्रदान करता है, जो किसी दिए गए नंबर की सीमा में पहला तत्व ढूंढता है जो एक पूर्ण वर्ग और साथ ही एक पूर्णांक - है

let array1 = [| 2 .. 100 |]
let delta = 1.0e-10
let isPerfectSquare (x:int) =
   let y = sqrt (float x)
   abs(y - round y) < delta

let isPerfectCube (x:int) =
   let y = System.Math.Pow(float x, 1.0/3.0)
   abs(y - round y) < delta

let element = Array.find (fun elem -> isPerfectSquare elem && isPerfectCube elem) array1

let index = Array.findIndex (fun elem -> isPerfectSquare elem && isPerfectCube elem) array1

printfn "The first element that is both a square and a cube is %d and its index is %d." element index

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

The first element that is both a square and a cube is 64 and its index is 62.