फोरट्रान - डायनेमिक एरे

dynamic array एक सरणी है, जिसका आकार संकलन समय पर ज्ञात नहीं है, लेकिन निष्पादन समय पर जाना जाएगा।

गतिशील सरणियों को विशेषता के साथ घोषित किया जाता है allocatable

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

real, dimension (:,:), allocatable :: darray

सरणी की रैंक, यानी, आयामों का उल्लेख किया जाना चाहिए, लेकिन इस तरह के एक सरणी को मेमोरी आवंटित करने के लिए, आप इसका उपयोग करते हैं allocate समारोह।

allocate ( darray(s1,s2) )

सरणी का उपयोग करने के बाद, प्रोग्राम में, बनाई गई मेमोरी को उपयोग करके मुक्त किया जाना चाहिए deallocate समारोह

deallocate (darray)

उदाहरण

निम्न उदाहरण ऊपर चर्चा की गई अवधारणाओं को प्रदर्शित करता है।

program dynamic_array 
implicit none 

   !rank is 2, but size not known   
   real, dimension (:,:), allocatable :: darray    
   integer :: s1, s2     
   integer :: i, j     
   
   print*, "Enter the size of the array:"     
   read*, s1, s2      
   
   ! allocate memory      
   allocate ( darray(s1,s2) )      
   
   do i = 1, s1           
      do j = 1, s2                
         darray(i,j) = i*j               
         print*, "darray(",i,",",j,") = ", darray(i,j)           
      end do      
   end do      
   
   deallocate (darray)  
end program dynamic_array

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Enter the size of the array: 3,4
darray( 1 , 1 ) = 1.00000000    
darray( 1 , 2 ) = 2.00000000    
darray( 1 , 3 ) = 3.00000000    
darray( 1 , 4 ) = 4.00000000    
darray( 2 , 1 ) = 2.00000000    
darray( 2 , 2 ) = 4.00000000    
darray( 2 , 3 ) = 6.00000000    
darray( 2 , 4 ) = 8.00000000    
darray( 3 , 1 ) = 3.00000000    
darray( 3 , 2 ) = 6.00000000    
darray( 3 , 3 ) = 9.00000000    
darray( 3 , 4 ) = 12.0000000

डेटा स्टेटमेंट का उपयोग

data स्टेटमेंट को एक से अधिक एरे को इनिशियलाइज़ करने के लिए या ऐरे सेक्शन आरंभीकरण के लिए इस्तेमाल किया जा सकता है।

डेटा स्टेटमेंट का सिंटैक्स है -

data variable / list / ...

उदाहरण

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

program dataStatement
implicit none

   integer :: a(5), b(3,3), c(10),i, j
   data a /7,8,9,10,11/ 
   
   data b(1,:) /1,1,1/ 
   data b(2,:)/2,2,2/ 
   data b(3,:)/3,3,3/ 
   data (c(i),i = 1,10,2) /4,5,6,7,8/ 
   data (c(i),i = 2,10,2)/5*2/
   
   Print *, 'The A array:'
   do j = 1, 5                
      print*, a(j)           
   end do 
   
   Print *, 'The B array:'
   do i = lbound(b,1), ubound(b,1)
      write(*,*) (b(i,j), j = lbound(b,2), ubound(b,2))
   end do

   Print *, 'The C array:' 
   do j = 1, 10                
      print*, c(j)           
   end do      
   
end program dataStatement

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

The A array:
           7
           8
           9
          10
          11
 The B array:
           1           1           1
           2           2           2
           3           3           3
 The C array:
           4
           2
           5
           2
           6
           2
           7
           2
           8
           2

कहां का उपयोग वक्तव्य

whereकथन आपको कुछ तार्किक स्थिति के परिणाम के आधार पर एक अभिव्यक्ति में सरणी के कुछ तत्वों का उपयोग करने की अनुमति देता है। यह किसी तत्व पर अभिव्यक्ति के निष्पादन की अनुमति देता है, यदि दी गई स्थिति सत्य है।

उदाहरण

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

program whereStatement
implicit none

   integer :: a(3,5), i , j
   
   do i = 1,3
      do j = 1, 5                
         a(i,j) = j-i          
      end do 
   end do
   
   Print *, 'The A array:'
   
   do i = lbound(a,1), ubound(a,1)
      write(*,*) (a(i,j), j = lbound(a,2), ubound(a,2))
   end do
   
   where( a<0 ) 
      a = 1 
   elsewhere
      a = 5
   end where
  
   Print *, 'The A array:'
   do i = lbound(a,1), ubound(a,1)
      write(*,*) (a(i,j), j = lbound(a,2), ubound(a,2))
   end do   
   
end program whereStatement

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

The A array:
           0           1           2           3           4
          -1           0           1           2           3
          -2          -1           0           1           2
 The A array:
           5           5           5           5           5
           1           5           5           5           5
           1           1           5           5           5