क्यू भाषा - अनुक्रमण
एक सूची को उसके आइटम की स्थिति से बाएं से दाएं की ओर क्रमबद्ध किया जाता है। सूची की शुरुआत से किसी आइटम की ऑफसेट को कहा जाता हैindex। इस प्रकार, पहले आइटम में एक इंडेक्स 0 है, दूसरा आइटम (यदि कोई है तो) का इंडेक्स 1 है, आदि गिनती की एक सूची हैn से इंडेक्स डोमेन है 0 सेवा n–1।
सूचकांक संकेतन
एक सूची दी L, सूचकांक में आइटम i द्वारा पहुँचा है L[i]। किसी वस्तु को उसके सूचकांक द्वारा पुनः प्राप्त करना कहते हैंitem indexing। उदाहरण के लिए,
q)L:(99;98.7e;`b;`abc;"z")
q)L[0]
99
q)L[1]
98.7e
q)L[4]
"z
अनुक्रमित असाइनमेंट
सूची में आइटम को आइटम अनुक्रमण के माध्यम से भी सौंपा जा सकता है। इस प्रकार,
q)L1:9 8 7
q)L1[2]:66 / Indexed assignment into a simple list
/ enforces strict type matching.
q)L1
9 8 66
चर से सूचियाँ
q)l1:(9;8;40;200)
q)l2:(1 4 3; `abc`xyz)
q)l:(l1;l2) / combining the two list l1 and l2
q)l
9 8 40 200
(1 4 3;`abc`xyz)
सूची में शामिल होना
दो सूचियों पर सबसे आम ऑपरेशन एक बड़ी सूची बनाने के लिए उन्हें एक साथ जोड़ना है। अधिक सटीक रूप से, शामिल होने वाला ऑपरेटर (), अपने दाहिने ऑपरेंड को बाएं ऑपरेंड के अंत में जोड़ता है और परिणाम देता है। यह किसी भी तर्क में एक परमाणु को स्वीकार करता है।
q)1,2 3 4
1 2 3 4
q)1 2 3, 4.4 5.6 / If the arguments are not of uniform type,
/ the result is a general list.
1
2
3
4.4
5.6
घोंसला करने की क्रिया
डेटा जटिलता सूचियों के आइटम के रूप में सूचियों का उपयोग करके बनाया गया है।
गहराई
किसी सूची के लिए घोंसले के स्तर की संख्या को इसकी गहराई कहा जाता है। परमाणुओं की गहराई 0 है और सरल सूचियों की गहराई 1 है।
q)l1:(9;8;(99;88))
q)count l1
3
यहाँ गहराई 3 की सूची दो आइटम हैं -
q)l5
9
(90;180;900 1800 2700 3600)
q)count l5
2
q)count l5[1]
3
गहराई पर अनुक्रमण
एक नेस्टेड सूची के आइटम में सीधे अनुक्रमण करना संभव है।
Repeated Item Indexing
किसी एकल अनुक्रमणिका के माध्यम से किसी आइटम को पुनर्प्राप्त करना हमेशा एक नेस्टेड सूची से एक ऊपरवाला आइटम पुनर्प्राप्त करता है।
q)L:(1;(100;200;(300;400;500;600)))
q)L[0]
1
q)L[1]
100
200
300 400 500 600
परिणाम के बाद से L[1] अपने आप में एक सूची है, हम एक एकल सूचकांक का उपयोग करके इसके तत्वों को पुनः प्राप्त कर सकते हैं।
q)L[1][2]
300 400 500 600
हम एक सूची को एक बार फिर से दोहरा सकते हैं ताकि अंतरतम नेस्टेड सूची से किसी आइटम को पुनः प्राप्त किया जा सके।
q)L[1][2][0]
300
आप इसे पढ़ सकते हैं,
आइटम को L से अनुक्रमणिका 1 पर प्राप्त करें, और इससे अनुक्रमणिका 2 पर आइटम को पुनः प्राप्त करें, और इससे आइटम को अनुक्रमणिका 0 पर पुनः प्राप्त करें।
Notation for Indexing at Depth
एक नेस्टेड सूची के घटकों में बार-बार अनुक्रमण के लिए एक वैकल्पिक संकेतन है। अंतिम पुनर्प्राप्ति के रूप में भी लिखा जा सकता है,
q)L[1;2;0]
300
सूचकांक के माध्यम से असाइनमेंट भी गहराई से काम करता है।
q)L[1;2;1]:900
q)L
1
(100;200;300 900 500 600)
ऐलिड इंडिसेस
Eliding Indices for a General List
q)L:((1 2 3; 4 5 6 7); (`a`b`c;`d`e`f`g;`0`1`2);("good";"morning"))
q)L
(1 2 3;4 5 6 7)
(`a`b`c;`d`e`f`g;`0`1`2)
("good";"morning")
q)L[;1;]
4 5 6 7
`d`e`f`g
"morning"
q)L[;;2]
3 6
`c`f`2
"or"
Interpret L[;1;] as,
शीर्ष स्तर पर प्रत्येक सूची की दूसरी स्थिति में सभी वस्तुओं को पुनः प्राप्त करें।
Interpret L[;;2] as,
दूसरे स्तर पर प्रत्येक सूची के लिए तीसरे स्थान पर आइटम को पुनः प्राप्त करें।