Computer >> कंप्यूटर ट्यूटोरियल >  >> प्रोग्रामिंग >> Python

पायथन में कुछ संचालन करके किसी दिए गए सरणी के उप-सरणियों का अपेक्षित योग खोजने का कार्यक्रम

कुछ संचालन करके किसी दिए गए सरणी के उप-सरणियों का अपेक्षित योग खोजने का कार्यक्रम

मान लीजिए हमारे पास एक सरणी A है जिसका आकार n है और दो मान p और q हैं। हम ये ऑपरेशन A.

. पर कर सकते हैं
  • यादृच्छिक रूप से दो अनुक्रमणिका (l, r) का चयन करें जहां l
  • यादृच्छिक रूप से दो अनुक्रमणिका (l, r) का चयन करें जहां l

पहला ऑपरेशन p कई बार और दूसरा ऑपरेशन q बार करने के बाद, हम बेतरतीब ढंग से दो इंडेक्स l &r का चयन करते हैं जहां l

इसलिए, यदि इनपुट A =[1,2,3] p =1 q =1 जैसा है, तो आउटपुट 4.667 होगा क्योंकि

चरण 1:हमारे पास तीन विकल्प हैं -

  • स्वैप (0, 1) तो सरणी 2 1 3 होगी

  • स्वैप (0, 2) तो सरणी 3 2 1

    . होगी
  • स्वैप(1, 2) तो सरणी 1 3 2 होगी

चरण 2:हमारे पास प्रत्येक परिणाम के लिए फिर से तीन विकल्प हैं -

  • [2 1 3] से [1 2 3], [3 1 2], [2 3 1]

  • [3 2 1] से [2 3 1], [1 2 3], [3 1 2]

  • [1 3 2] से [3 1 2], [2 3 1], [1 2 3]

9 संभावित सरणियाँ हैं इसलिए संभावना 1/9 है। तो 9 सरणियों में से प्रत्येक में समान संभावना के साथ 3 संभावित योग होंगे। उदाहरण के लिए, [1 2 3], हम 1+2, 2+3 और 1+2+3 प्राप्त कर सकते हैं। और इस इनपुट के लिए कुल 27 परिणाम हैं, सभी 27S का योग ज्ञात करके और इसे 27 से विभाजित करके अपेक्षित मान की गणना की जा सकती है।

इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -

  • एक फ़ंक्शन को परिभाषित करें matmul() । इसमें a, v, n
  • . लगेगा
  • toret :=आकार n की एक सरणी और 0 से भरें
  • मैं के लिए 0 से n -1 की सीमा में, करो
    • जे के लिए 0 से n -1 की सीमा में, करो
      • toret[i] :=toret[i] + a[i, j]*v[j]
  • रिटर्न टोरेट
  • मुख्य विधि से, निम्न कार्य करें:
  • n :=A का आकार
  • अस्थायी:=एक नई सूची
  • swp :=(n - 3) /(n - 1)
  • स्वैपवलप :=((swp^p)*(n - 1) + 1) /n
  • स्वैपवाल्म :=(1 - (swp^p)) /n
  • रेव :=एक नई खाली सूची
  • dotv :=एक नई खाली सूची
  • मैं के लिए 0 से n -1 की सीमा में, करो
    • स्वैपरो :=एक नई खाली सूची
    • revrow :=एक नई खाली सूची
    • जे के लिए 0 से n -1 की सीमा में, करो
      • स्वैपवल्म को स्वैप्रो के अंत में डालें
      • रिवो के अंत में 2*(न्यूनतम i, j, (n-i-1) और (n-j-1+1)/(n*(n - 1)) डालें
    • स्वैपरो :=एक नई खाली सूची
    • revrow :=एक नई खाली सूची
    • जे के लिए 0 से n-1 की सीमा में, करें
    • स्वैपरो[i] :=swapvalp
    • revrow[i] :=1.0 - 2*((i + 1)*(n - i) - न्यूनतम (i+1) और (n - i))/(n*(n-1))
    • अस्थायी के अंत में स्वैपरो डालें
    • रेव के अंत में रेवो डालें
    • dotv के अंत में 2*((i+1)*(n-i) - 1)/(n*(n-1)) डालें
  • A :=matmul(temp, A, n)
  • 0 से q की सीमा में i के लिए, करें
    • A :=matmul(rev, A, n)
  • कुल:=0.0
  • 0 से n की सीमा में i के लिए, करें
    • कुल:=टोट + डॉटव[i]*A[i]
  • रिटर्न टोटल

उदाहरण

आइए बेहतर समझ पाने के लिए निम्नलिखित कार्यान्वयन देखें -

def matmul(a, v, n):
   toret = [0]*n
   for i in range(n):
      for j in range(n):
         toret[i] += a[i][j]*v[j]
   return toret

def solve(A, p, q):
   n = len(A)
   temp = []
   swp = (n - 3)/(n - 1)
   swapvalp = (pow(swp, p)*(n - 1) + 1)/n
   swapvalm = (1 - pow(swp, p))/n
   rev = []
   dotv = []
   for i in range(n):
      swaprow = []
      revrow = []
      for j in range(n):
         swaprow.append(swapvalm)
         revrow.append(2*(min(i, j, n - i - 1, n - j - 1) + 1)/(n*(n - 1)))
      swaprow[i] = swapvalp
      revrow[i] = 1.0 - 2*((i + 1)*(n - i) - min(i + 1, n - i))/(n*(n - 1))
      temp.append(swaprow)
      rev.append(revrow)
      dotv.append(2*((i + 1)*(n - i) - 1)/(n*(n - 1)))

   A = matmul(temp, A, n)
   for _ in range(q):
      A = matmul(rev, A, n)

   tot = 0.0
   for i in range(n):
      tot += dotv[i]*A[i]

   return tot

A = [1,2,3]
p = 1
q = 1
print(solve(A, p, q))

इनपुट

[1,2,3], 1, 1

आउटपुट

0.0

  1. - कुछ संख्याओं का गुणनफल खोजने का कार्यक्रम जिसका योग पायथन में दिया गया है

    मान लीजिए कि हमारे पास एक संख्या n है, हमें दो या दो से अधिक संख्याएँ इस प्रकार ज्ञात करनी हैं कि उनका योग n के बराबर हो, और इन संख्याओं का गुणनफल अधिकतम हो, तो हमें गुणनफल ज्ञात करना होगा। इसलिए, यदि इनपुट n =12 जैसा है, तो आउटपुट 81 होगा, जैसे 3 + 3 + 3 + 3 =12 और 3 * 3 * 3 * 3 =81। इसे हल करने

  1. पायथन प्रोग्राम में सरणी का योग ज्ञात करें पायथन प्रोग्राम में सरणी का योग ज्ञात करें

    इस लेख में, हम नीचे दिए गए समस्या कथन के समाधान के बारे में जानेंगे। समस्या कथन - हमें एक सरणी दी गई है, जिसकी हमें सरणी के योग की गणना करने की आवश्यकता है। योग प्राप्त करने के लिए प्रत्येक अनुक्रमणिका में संपूर्ण सरणी और तत्व को पार करने के लिए पाशविक-बल दृष्टिकोण की चर्चा नीचे प्रत्येक अनुक्रमण

  1. सरणी का योग खोजने के लिए पायथन कार्यक्रम सरणी का योग खोजने के लिए पायथन कार्यक्रम

    इस लेख में, हम दिए गए समस्या कथन को हल करने के लिए समाधान और दृष्टिकोण के बारे में जानेंगे। समस्या कथन एक इनपुट के रूप में एक सरणी को देखते हुए, हमें दिए गए सरणी के योग की गणना करने की आवश्यकता है। यहां हम ब्रूट-फोर्स अप्रोच का अनुसरण कर सकते हैं, यानी एक सूची को पार करना और प्रत्येक तत्व को एक खा