डी प्रोग्रामिंग - एरेस
डी प्रोग्रामिंग भाषा एक डेटा संरचना प्रदान करती है, जिसका नाम है arrays, जो एक ही प्रकार के तत्वों के एक निश्चित आकार के अनुक्रमिक संग्रह को संग्रहीत करता है। डेटा संग्रह को संग्रहीत करने के लिए एक सरणी का उपयोग किया जाता है। एक सरणी के समान प्रकार के संग्रह के रूप में एक सरणी के बारे में सोचना अक्सर अधिक उपयोगी होता है।
नंबर चर, नंबर 1, ... और नंबर 99 जैसे अलग-अलग चर घोषित करने के बजाय, आप एक सरणी चर जैसे संख्याओं की घोषणा करते हैं और संख्याओं का उपयोग करते हैं [0], संख्याओं [1] और ..., संख्याओं [99] का प्रतिनिधित्व करने के लिए। अलग-अलग चर। एक सरणी में एक विशिष्ट तत्व एक सूचकांक द्वारा पहुँचा जाता है।
सभी सरणियों में सन्निहित स्मृति स्थान शामिल हैं। निम्नतम पता पहले तत्व से मेल खाता है और अंतिम तत्व से उच्चतम पता।
घोषणाएँ
डी प्रोग्रामिंग भाषा में एक सरणी घोषित करने के लिए, प्रोग्रामर तत्वों की संख्या और एक सरणी द्वारा आवश्यक तत्वों की संख्या को निर्दिष्ट करता है:
type arrayName [ arraySize ];
इसे एकल-आयाम सरणी कहा जाता है। ArraySize शून्य से एक पूर्णांक लगातार अधिक होना चाहिए और प्रकार किसी भी मान्य डी प्रोग्रामिंग भाषा डेटा प्रकार हो सकता है। उदाहरण के लिए, एक 10-तत्व सरणी घोषित करने के लिए जिसे बैलेंस डबल कहा जाता है , इस कथन का उपयोग करें -
double balance[10];
आरंभिक सारणी
आप डी प्रोग्रामिंग लैंग्वेज ऐरे एलीमेंट्स को एक-एक करके या एक स्टेटमेंट को निम्नानुसार इनिशियलाइज़ कर सकते हैं
double balance[5] = [1000.0, 2.0, 3.4, 17.0, 50.0];
वर्ग कोष्ठक के बीच मानों की संख्या [] दायीं ओर वर्ग कोष्ठक के बीच के सरणी के लिए घोषित तत्वों की संख्या से बड़ी नहीं हो सकती है []। निम्न उदाहरण सरणी का एक तत्व प्रदान करता है -
यदि आप सरणी के आकार को छोड़ देते हैं, तो आरंभीकरण धारण करने के लिए सिर्फ एक सरणी काफी बड़ी है। इसलिए, यदि आप लिखते हैं
double balance[] = [1000.0, 2.0, 3.4, 17.0, 50.0];
तब आप बिलकुल उसी सरणी को बनाएंगे जैसा आपने पिछले उदाहरण में बनाया था।
balance[4] = 50.0;
उपरोक्त कथन सरणी में तत्व संख्या 5 को 50.0 का मान प्रदान करता है। 4 वें इंडेक्स के साथ ऐरे 5 वें, यानी, अंतिम तत्व होगा क्योंकि सभी सरणियों में उनके पहले तत्व के इंडेक्स के रूप में 0 होता है जिसे बेस इंडेक्स भी कहा जाता है। निम्नलिखित चित्रात्मक प्रतिनिधित्व वही सरणी दिखाता है जिसकी हमने ऊपर चर्चा की है -
ऐरे तत्वों तक पहुँचना
सरणी नाम अनुक्रमित करके एक तत्व को एक्सेस किया जाता है। यह सरणी के नाम के बाद वर्ग ब्रैकेट के भीतर तत्व के सूचकांक को रखकर किया जाता है। उदाहरण के लिए -
double salary = balance[9];
उपरोक्त कथन सरणी से 10 वें तत्व को लेता है और मान को वैरिएबल सैलरी पर असाइन करता है । निम्नलिखित उदाहरण घोषणा, कार्य, और पहुंच सरणियों को लागू करता है -
import std.stdio;
void main() {
int n[ 10 ]; // n is an array of 10 integers
// initialize elements of array n to 0
for ( int i = 0; i < 10; i++ ) {
n[ i ] = i + 100; // set element at location i to i + 100
}
writeln("Element \t Value");
// output each array element's value
for ( int j = 0; j < 10; j++ ) {
writeln(j," \t ",n[j]);
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Element Value
0 100
1 101
2 102
3 103
4 104
5 105
6 106
7 107
8 108
9 109
स्टेटिक एरेस वर्सेस डायनेमिक एरे
यदि प्रोग्राम लिखते समय किसी ऐरे की लंबाई निर्दिष्ट की जाती है, तो वह ऐरे एक स्थिर ऐरे है। जब कार्यक्रम के निष्पादन के दौरान लंबाई बदल सकती है, तो वह सरणी एक गतिशील सरणी है।
डायनेमिक सरणियों को परिभाषित करना निश्चित-लंबाई सरणियों को परिभाषित करने की तुलना में सरल है क्योंकि लंबाई को छोड़ना एक गतिशील सरणी बनाता है -
int[] dynamicArray;
ऐरे गुण
यहाँ ऐरे के गुण हैं -
अनु क्रमांक। | संपत्ति विवरण |
---|---|
1 | .init स्टेटिक ऐरे एक एरे शाब्दिक रिटर्न देता है जिसमें शाब्दिक के प्रत्येक तत्व के साथ ऐरे तत्व प्रकार की .init प्रॉपर्टी होती है। |
2 | .sizeof स्टेटिक सरणी सरणी लंबाई को सरणी तत्व प्रति बाइट की संख्या से गुणा करती है जबकि डायनेमिक सरणियाँ डायनेमिक सरणी संदर्भ का आकार लौटाती है, जो 32-बिट बिल्ड में 8 और 64-बिट बिल्ड पर 16 है। |
3 | .length स्टेटिक एरे सरणी में तत्वों की संख्या देता है जबकि गतिशील एरे को सरणी में तत्वों की संख्या प्राप्त / सेट करने के लिए उपयोग किया जाता है। लंबाई type_t की है। |
4 | .ptr सरणी के पहले तत्व के लिए एक सूचक लौटाता है। |
5 | .dup उसी आकार का एक डायनामिक ऐरे बनाएं और उसमें ऐरे के कंटेंट को कॉपी करें। |
6 | .idup उसी आकार का एक डायनामिक ऐरे बनाएं और उसमें ऐरे के कंटेंट को कॉपी करें। नकल अपरिवर्तनीय के रूप में टाइप की गई है। |
7 | .reverse सरणी में तत्वों के क्रम को उलट देता है। सरणी लौटाता है। |
8 | .sort सरणी में तत्वों के क्रम को जगह देता है। सरणी लौटाता है। |
उदाहरण
निम्नलिखित उदाहरण एक सरणी के विभिन्न गुणों की व्याख्या करता है -
import std.stdio;
void main() {
int n[ 5 ]; // n is an array of 5 integers
// initialize elements of array n to 0
for ( int i = 0; i < 5; i++ ) {
n[ i ] = i + 100; // set element at location i to i + 100
}
writeln("Initialized value:",n.init);
writeln("Length: ",n.length);
writeln("Size of: ",n.sizeof);
writeln("Pointer:",n.ptr);
writeln("Duplicate Array: ",n.dup);
writeln("iDuplicate Array: ",n.idup);
n = n.reverse.dup;
writeln("Reversed Array: ",n);
writeln("Sorted Array: ",n.sort);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Initialized value:[0, 0, 0, 0, 0]
Length: 5
Size of: 20
Pointer:7FFF5A373920
Duplicate Array: [100, 101, 102, 103, 104]
iDuplicate Array: [100, 101, 102, 103, 104]
Reversed Array: [104, 103, 102, 101, 100]
Sorted Array: [100, 101, 102, 103, 104]
डी में मल्टी डायमेंशनल एरर्स
डी प्रोग्रामिंग बहुआयामी सरणियों की अनुमति देता है। यहाँ एक बहुआयामी सरणी घोषणा का सामान्य रूप है -
type name[size1][size2]...[sizeN];
उदाहरण
निम्नलिखित घोषणा एक तीन आयामी 5 बनाता है। १०। 4 पूर्णांक सरणी -
int threedim[5][10][4];
डी में दो-आयामी तीर
बहुआयामी सरणी का सबसे सरल रूप द्वि-आयामी सरणी है। एक द्वि-आयामी सरणी, संक्षेप में, एक-आयामी सरणियों की एक सूची है। आकार के दो आयामी पूर्णांक सरणी घोषित करने के लिए [x, y] आप सिंटैक्स को निम्नानुसार लिखेंगे -
type arrayName [ x ][ y ];
कहाँ पे type किसी भी मान्य डी प्रोग्रामिंग डेटा प्रकार और हो सकता है arrayName एक मान्य डी प्रोग्रामिंग पहचानकर्ता होगा।
जहाँ प्रकार कोई भी मान्य D प्रोग्रामिंग डेटा प्रकार हो सकता है और arrayName एक मान्य D प्रोग्रामिंग पहचानकर्ता है।
एक दो-आयामी सरणी को एक तालिका के रूप में सोचा जा सकता है, जिसमें x संख्या में पंक्तियां और y संख्या में स्तंभ हैं। एक दो आयामी सरणीa तीन पंक्तियों और चार स्तंभों को निम्नानुसार दिखाया जा सकता है -
इस प्रकार, सरणी में प्रत्येक तत्व a एक तत्व के रूप में पहचाना जाता है a[ i ][ j ], कहाँ पे a सरणी का नाम है, और i तथा j सदस्यताएँ हैं जो विशिष्ट रूप से प्रत्येक तत्व को एक में पहचानती हैं।
दो आयामी आयामों की शुरुआत
प्रत्येक पंक्ति के लिए ब्रैकेटेड मान निर्दिष्ट करके बहु-स्तरीय सरणियों को आरंभ किया जा सकता है। निम्न सरणी में 3 पंक्तियाँ हैं और प्रत्येक पंक्ति में 4 स्तंभ हैं।
int a[3][4] = [
[0, 1, 2, 3] , /* initializers for row indexed by 0 */
[4, 5, 6, 7] , /* initializers for row indexed by 1 */
[8, 9, 10, 11] /* initializers for row indexed by 2 */
];
नेस्टेड ब्रेसिज़, जो इच्छित पंक्ति को इंगित करते हैं, वैकल्पिक हैं। निम्न आरंभीकरण पिछले उदाहरण के बराबर है -
int a[3][4] = [0,1,2,3,4,5,6,7,8,9,10,11];
दो-आयामी सरणी तत्वों तक पहुंचना
2-आयामी सरणी में एक तत्व सब्सक्राइब का उपयोग करके एक्सेस किया जाता है, मतलब पंक्ति इंडेक्स और एरे का कॉलम इंडेक्स। उदाहरण के लिए
int val = a[2][3];
उपरोक्त कथन सरणी की तीसरी पंक्ति से 4 वाँ तत्व लेता है। आप इसे उपरोक्त डिग्राम में सत्यापित कर सकते हैं।
import std.stdio;
void main () {
// an array with 5 rows and 2 columns.
int a[5][2] = [ [0,0], [1,2], [2,4], [3,6],[4,8]];
// output each array element's value
for ( int i = 0; i < 5; i++ ) for ( int j = 0; j < 2; j++ ) {
writeln( "a[" , i , "][" , j , "]: ",a[i][j]);
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
a[0][0]: 0
a[0][1]: 0
a[1][0]: 1
a[1][1]: 2
a[2][0]: 2
a[2][1]: 4
a[3][0]: 3
a[3][1]: 6
a[4][0]: 4
a[4][1]: 8
डी में आम ऐरे ऑपरेशन
यहाँ ऐरे पर विभिन्न ऑपरेशन किए गए हैं -
अर्रे स्लाइसिंग
हम अक्सर एक सरणी का हिस्सा उपयोग करते हैं और टुकड़ा करने की क्रिया अक्सर काफी सहायक होते हैं। सरणी टुकड़ा करने की क्रिया के लिए एक सरल उदाहरण नीचे दिखाया गया है।
import std.stdio;
void main () {
// an array with 5 elements.
double a[5] = [1000.0, 2.0, 3.4, 17.0, 50.0];
double[] b;
b = a[1..3];
writeln(b);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
[2, 3.4]
एरियर कॉपी करना
हम नकल सरणी का भी उपयोग करते हैं। सरणी प्रतिलिपि के लिए एक सरल उदाहरण नीचे दिखाया गया है।
import std.stdio;
void main () {
// an array with 5 elements.
double a[5] = [1000.0, 2.0, 3.4, 17.0, 50.0];
double b[5];
writeln("Array a:",a);
writeln("Array b:",b);
b[] = a; // the 5 elements of a[5] are copied into b[5]
writeln("Array b:",b);
b[] = a[]; // the 5 elements of a[3] are copied into b[5]
writeln("Array b:",b);
b[1..2] = a[0..1]; // same as b[1] = a[0]
writeln("Array b:",b);
b[0..2] = a[1..3]; // same as b[0] = a[1], b[1] = a[2]
writeln("Array b:",b);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Array a:[1000, 2, 3.4, 17, 50]
Array b:[nan, nan, nan, nan, nan]
Array b:[1000, 2, 3.4, 17, 50]
Array b:[1000, 2, 3.4, 17, 50]
Array b:[1000, 1000, 3.4, 17, 50]
Array b:[2, 3.4, 3.4, 17, 50]
ऐरे सेटिंग
किसी सरणी में मान सेट करने के लिए एक सरल उदाहरण नीचे दिखाया गया है।
import std.stdio;
void main () {
// an array with 5 elements.
double a[5];
a[] = 5;
writeln("Array a:",a);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Array a:[5, 5, 5, 5, 5]
एरे कॉन्टैक्नेशन
दो सरणियों के संघनन के लिए एक सरल उदाहरण नीचे दिखाया गया है।
import std.stdio;
void main () {
// an array with 5 elements.
double a[5] = 5;
double b[5] = 10;
double [] c;
c = a~b;
writeln("Array c: ",c);
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Array c: [5, 5, 5, 5, 5, 10, 10, 10, 10, 10]