कोडगॉल्फ रेनबो: ड्रा इन ब्लैक-एंड-व्हाइट


12

परिचय:

यहाँ छवि विवरण दर्ज करें(स्रोत: विकिपीडिया )
जब हम एक इंद्रधनुष को देखते हैं तो उसमें हमेशा ऊपर से नीचे तक रंग होंगे:
लाल; संतरा; पीला; हरा; नीला; इंडिगो; बैंगनी

अगर हम इन अलग-अलग रिंगों को देखें, तो लाल रिंग वायलेट रिंग से बड़ी होती है।
इसके अलावा, एक ही समय में दो या तीन इंद्रधनुष होना भी संभव है।

इस चुनौती में उपरोक्त सभी का उपयोग किया जाएगा:

चुनौती:

एक पूर्णांक को देखते हुए n, आउटपुट जो कि (संभवतः एक से अधिक) 'इंद्रधनुष' के कई छल्ले हैं, जहां हम vibgyorरंगों के लिए अक्षरों का उपयोग करेंगे ।

नीचे दिए गए परीक्षण मामलों को देखें कि वे किस तरह से ऊपर की ओर निर्मित हैं n=1, और रिक्ति को कैसे (पर n=8) संभाला जाना चाहिए । जैसा कि आप देख सकते हैं, दो इंद्रधनुष के बीच एक स्थान जोड़ा जाता है, जिसमें शीर्ष पर स्पेसिंग शामिल है, इससे पहले कि हम अगले इंद्रधनुष की अंगूठी को पंक्ति में जोड़ दें।

चुनौती नियम:

  • आपको VIBGYORलोअरकेस के बजाय पूंजी का उपयोग करने की अनुमति है
  • व्यक्तिगत इंद्रधनुष के बीच एक स्थान होना चाहिए
  • प्रमुख इंद्रधनुष और / या अनुगामी स्थानों / नई-लाइनों की किसी भी राशि की अनुमति दी जाती है, जब तक कि वास्तविक इंद्रधनुष (जहां भी इसे स्क्रीन पर रखा गया है) सही है
  • इनपुट हमेशा एक सकारात्मक पूर्णांक ( >= 1) होगा। जब व्यवहार n=0अपरिभाषित होता है, और प्रोग्राम / फ़ंक्शन जो कुछ भी चाहता है वह कर सकता है (कुछ भी n=1उत्पादन नहीं करता; इंद्रधनुष का उत्पादन; यादृच्छिक आउटपुट; एक त्रुटि के साथ असफल; आदि;)
  • यदि आप चाहें तो तार की सूची / सरणी या 2D सरणी / वर्णों की सूची को आउटपुट करने की अनुमति है (आप TIO पाद लेख में वास्तविक सुंदर मुद्रण कोड जोड़ सकते हैं)।
  • इस तथ्य को नजरअंदाज करें कि रेनबो की तुलना में आउटपुट मय मंदिरों की तरह दिखता है .. xD

सामान्य नियम:

  • यह , इसलिए बाइट्स जीत में सबसे छोटा जवाब है।
    कोड-गोल्फ भाषाओं को गैर-कोडगॉल्फिंग भाषाओं के साथ उत्तर पोस्ट करने से हतोत्साहित न करें। 'किसी भी' प्रोग्रामिंग भाषा के लिए यथासंभव संक्षिप्त उत्तर के साथ आने का प्रयास करें।
  • मानक नियम आपके उत्तर के लिए लागू होते हैं , इसलिए आपको उचित पैरामीटर और रिटर्न-टाइप, पूर्ण कार्यक्रमों के साथ STDIN / STDOUT, फ़ंक्शन / विधि का उपयोग करने की अनुमति है। तुम्हारा कॉल।
  • डिफ़ॉल्ट लूपोल्स वर्जित हैं।
  • यदि संभव हो, तो कृपया अपने कोड के लिए एक परीक्षण के साथ एक लिंक जोड़ें।
  • साथ ही, आपके उत्तर के लिए स्पष्टीकरण जोड़ना अत्यधिक अनुशंसित है।

परीक्षण के मामले (पहले के n=1माध्यम से n=10, और n=25):

1:
 vvv
v   v

2:
  iii
 ivvvi
iv   vi

3:
   bbb
  biiib
 bivvvib
biv   vib

4:
    ggg
   gbbbg
  gbiiibg
 gbivvvibg
gbiv   vibg

5:
     yyy
    ygggy
   ygbbbgy
  ygbiiibgy
 ygbivvvibgy
ygbiv   vibgy

6:
      ooo
     oyyyo
    oygggyo
   oygbbbgyo
  oygbiiibgyo
 oygbivvvibgyo
oygbiv   vibgyo

7:
       rrr
      rooor
     royyyor
    roygggyor
   roygbbbgyor
  roygbiiibgyor
 roygbivvvibgyor
roygbiv   vibgyor

8:
         vvv
        v   v
       v rrr v
      v rooor v
     v royyyor v
    v roygggyor v
   v roygbbbgyor v
  v roygbiiibgyor v
 v roygbivvvibgyor v
v roygbiv   vibgyor v

9:
          iii
         ivvvi
        iv   vi
       iv rrr vi
      iv rooor vi
     iv royyyor vi
    iv roygggyor vi
   iv roygbbbgyor vi
  iv roygbiiibgyor vi
 iv roygbivvvibgyor vi
iv roygbiv   vibgyor vi

10:
           bbb
          biiib
         bivvvib
        biv   vib
       biv rrr vib
      biv rooor vib
     biv royyyor vib
    biv roygggyor vib
   biv roygbbbgyor vib
  biv roygbiiibgyor vib
 biv roygbivvvibgyor vib
biv roygbiv   vibgyor vib

25:
                            ggg
                           gbbbg
                          gbiiibg
                         gbivvvibg
                        gbiv   vibg
                       gbiv rrr vibg
                      gbiv rooor vibg
                     gbiv royyyor vibg
                    gbiv roygggyor vibg
                   gbiv roygbbbgyor vibg
                  gbiv roygbiiibgyor vibg
                 gbiv roygbivvvibgyor vibg
                gbiv roygbiv   vibgyor vibg
               gbiv roygbiv rrr vibgyor vibg
              gbiv roygbiv rooor vibgyor vibg
             gbiv roygbiv royyyor vibgyor vibg
            gbiv roygbiv roygggyor vibgyor vibg
           gbiv roygbiv roygbbbgyor vibgyor vibg
          gbiv roygbiv roygbiiibgyor vibgyor vibg
         gbiv roygbiv roygbivvvibgyor vibgyor vibg
        gbiv roygbiv roygbiv   vibgyor vibgyor vibg
       gbiv roygbiv roygbiv rrr vibgyor vibgyor vibg
      gbiv roygbiv roygbiv rooor vibgyor vibgyor vibg
     gbiv roygbiv roygbiv royyyor vibgyor vibgyor vibg
    gbiv roygbiv roygbiv roygggyor vibgyor vibgyor vibg
   gbiv roygbiv roygbiv roygbbbgyor vibgyor vibgyor vibg
  gbiv roygbiv roygbiv roygbiiibgyor vibgyor vibgyor vibg
 gbiv roygbiv roygbiv roygbivvvibgyor vibgyor vibgyor vibg
gbiv roygbiv roygbiv roygbiv   vibgyor vibgyor vibgyor vibg

3
हो सकता है कि आप यह जानते हों और यह डिजाइन के द्वारा हो (मुझे पता है कि इंद्रधनुष इंद्रधनुषी या असिसी नहीं हैं, और उच्चतर आदेशों की स्थिति अधिक जटिल होती है), लेकिन क्या दूसरे इंद्रधनुष में रंग उलटे नहीं हैं?
क्रिस एम

1
@ क्रिस आह, तुम वास्तव में सही हो। दो इंद्रधनुष के साथ दूसरा वास्तव में उलटा होता है , लेकिन तीन के साथ केवल बाहरी उलटा होता है , और चार के साथ दोनों बाहरी उलट होते हैं। आह ठीक है, अब इसे बदलने के लिए बहुत देर हो चुकी है। शायद मैं बाद में इसके साथ एक तीसरी संबंधित चुनौतियों के बारे में सोचूंगा। :)
केविन क्रूज़सेन


ओह कूल, एक अच्छा:
क्रिस एम

जवाबों:




3

05AB1E , 32 31 23 बाइट्स

.•VvÈ©•¹∍¬„ v:Rηε¬ý}.c

इसे ऑनलाइन आज़माएं!

-1 केविन क्रूज़सेन को धन्यवाद और -8 अदनान को धन्यवाद


स्पष्टीकरण (स्टैक उदाहरण w / 3 का इनपुट):

.•VvÈ©•                  # Push 'aibgyor'           | ['aibgyor']
       ¹∍                # Extend to input length.  | ['aib']
         ¬               # Push head.               | ['aib','a']
          „ v:           # Replace with ' v'.       | [' vib']
              R          # Reverse.                 | ['biv ']
               η         # Prefixes.                | ['b', 'bi', 'biv', 'biv ']
                ε   }    # For each....             | []
                 ¬ý     # Bifurcate, join by head. | ['b','b']       ->    ['bbb']
                                                    | ['bi','ib']     ->   ['biiib']
                                                    | ['biv','vib']   ->  ['bivvvib']
                                                    | ['biv ',' vib'] -> ['biv   vib']
                     .c # Center the result.        | Expected output.

1
"vibgyor"1 बाइट से गोल्फ हो सकता है .•2Bãθ(•। ( यहाँ इसके लिए स्पष्टीकरण " कैसे संपीड़ित करने के लिए शब्दकोष का हिस्सा नहीं है? " अनुभाग।) इसके अलावा, „vr…v r:ð«करने के लिए तैयार किया जा सकता है 'v„v .:। तो 28 बाइट्स । हालांकि अच्छा जवाब, मेरी तरफ से +1।
केविन क्रूज़सेन

2
@ केविनक्रूजसेन ओह मैं स्ट्रिंग कंप्रेशन के बारे में सब जानता हूं- मुझे अभी पता चला है (जैसा कि आमतौर पर सुपर छोटे स्ट्रिंग्स के साथ होता है) कि 3-बाइट ब्लोट .••नहीं बाइट बचाते हैं। आंकड़े एक बार मैं वास्तव में जांच नहीं करते समय यह xD बाइट्स की बचत होगी है। अच्छा पकड़
जादू ऑक्टोपस Urn

3
23 बाइट्स के लिए:.•VvÈ©•¹∍¬„ v:Rηε¬ý}.c
अदनान

1
@ अदनान काफी हद तक, दर्पण की कमी इसे मेरी आँखों में एक महत्वपूर्ण रिफ्लेक्टर बनाती है, हालांकि (और मुझे संदेह है कि मुझे अपने आप मिल गया होगा: पी)।
मैजिक ऑक्टोपस Urn

1
@ अदनान भी ¬ýजीनियस हैं ... जीज़ ... आप बहुत अलग सोचते हैं और यह कमाल है।
मैजिक ऑक्टोपस Urn

3

कैनवस , 29 28 26 बाइट्स

7÷U+{ <ibgyor@¹×/n}⇵K2*∔─↶

यहाँ यह कोशिश करो!

स्पष्टीकरण:

7÷U+                          ceil(input/7) + input
    {             }         for n in 1..the above
      <ibgyor@                in the string " <ibgyor", pick the nth character
              ¹×              repeat n times
                /             create a diagonal of that
                 n            and overlap the top 2 stack items (the 1st time around this does nothing, leaving an item for the next iterations)
                   ⇵        reverse the result vertically
                    K       take off the last line (e.g. " <ibgyor <ib")
                     2*     repeat that vertically twice
                       ∔    and append that back to the diagonals
                        ─   palindromize vertically
                         ↶  and rotate 90° anti-clockwise. This rotates "<" to "v"

25 24 22 बाइट्स तय करने के बाद कि अगर लंबाई वांछित है, तो इनपुट लंबाई से बड़ा है और 10 वीं बार की तरह ठीक करना चाहिए


जिज्ञासा से बाहर, vबग़ल में ( <) क्यों है ? है vपहले से ही कैनवास में एक आरक्षित कीवर्ड, यदि हां, तो क्यों उपयोग नहीं <है कि उलट कीवर्ड के रूप में?
केविन क्रूज़सेन

1
वर्णों का लंबवत उपयोग किया जाता है और फिर घुमाया जाता है, और कैनवस को यह पता लगाने के लिए पर्याप्त स्मार्ट बनाया जाता है कि <90 ° एंटिकलॉकवाइज बराबर होती है v: P सभी ASCII कैनवस btw में तार का हिस्सा हैं
dzaima

आह ठीक है, इसलिए यदि आपने vयहां उपयोग किया होता , और आप इसे 90 डिग्री वामावर्त घुमाते, तो यह >बदले में बन जाता । समझा। : D
केविन क्रूज़सेन

@ केविनक्रूजसेन के दूसरे नतीजे भी होंगे
dzaima

आह, तुम्हारा भी कहीं दर्पण है? मैं कैनवस tbh नहीं पढ़ सकता, इसलिए मैं कोड के स्पष्टीकरण की प्रतीक्षा कर रहा हूं। ;)
केविन क्रूज़सेन


3

डायलॉग एपीएल , 41 39 38 बाइट्स

↑{⌽(⌽,⊃,A↑⊢)⍵↑A' vibgyor'}¨-⍳A←⌈⎕×8÷7

इसे ऑनलाइन आज़माएं!

दूसरों के लिए एक समान दृष्टिकोण: A←⌈⎕×8÷7इंद्रधनुष की ऊंचाई (केंद्र की बाईं / दाईं ओर सबसे लंबी 'आधी पंक्ति की चौड़ाई भी) पाता है और इसे Aबाद के उपयोग के लिए असाइन करता है , जबकि ¨-⍳मानों के माध्यम से पुनरावृत्ति करता है। 1. ए, सही पक्ष पर चयन करने के लिए उन्हें negating जब साथ प्रयोग किया

A⍴' vibgyor'एक 'आधी पंक्ति' उत्पन्न ⍵↑करता है और सही लंबाई विकल्प का चयन करता है। (⌽,⊃,A↑⊢)रिवर्स पंक्ति में पूर्ण पंक्ति उत्पन्न करता है (जो करने के लिए कम वर्ण लेता है), एक उलटी हुई आधी पंक्ति ( ) के साथ शुरू होता है , फिर आधी पंक्ति स्ट्रिंग की शुरुआत से लिया गया केंद्र वर्ण ( ) और अंत में आधी पंक्ति का दायां गद्देदार संस्करण ( A↑⊢)। अंतिम पंक्ति को सही अभिविन्यास में उलट देता है और पंक्तियों के वेक्टर को 2 डी सरणी में बदल देता है।

संपादित करें: -दिज़िमा के लिए धन्यवाद

संपादित करें: -1 ngn के लिए धन्यवाद


आप के ⍕⍪साथ प्रतिस्थापित कर सकते हैं - वर्णों के 2 डी सरणी के
आउटपुट


1+÷7->8÷7
ngn 25'18


2

चारकोल , 30 बाइट्स

↶≔… vibgyor⁺²÷×⁸⊖N⁷θθ⸿Eθ✂θκ‖O←

इसे ऑनलाइन आज़माएं! लिंक कोड के वर्बोज़ संस्करण के लिए है। स्पष्टीकरण:

ड्राइंग की दिशा को ऊपर की ओर बदलें।

≔… vibgyor⁺²÷×⁸⊖N⁷θ

इंद्रधनुष की ऊंचाई की गणना करें और उस लंबाई तक शाब्दिक स्ट्रिंग को दोहराएं।

θ⸿

इंद्रधनुष की केंद्रीय रेखा प्रिंट करें।

Eθ✂θκ

क्रमिक स्लाइस लेकर इंद्रधनुष के दाहिने आधे हिस्से को प्रिंट करें और प्रत्येक को अपनी "लाइन" पर प्रिंट करें।

‖O←

इंद्रधनुष पूरा करने के लिए प्रतिबिंबित।



2

जेली , 28 बाइट्स

:7+‘“ vibgyor”ṁµṫJZz⁶U;"⁸ŒBṚ

एक पूर्णांक लिंक जो एक पूर्णांक को स्वीकार करता है जो वर्णों की सूची की एक सूची देता है।

इसे ऑनलाइन आज़माएं! (न्यूलाइन वर्णों के साथ पाद लेख जुड़ता है)

या परीक्षण-सूट देखें

कैसे?

:7+‘“ vibgyor”ṁµṫJZz⁶U;"⁸ŒBṚ - Link: integer
:7                           - integer divide by seven (number of full rainbows)
   ‘                         - increment (the input integer)
  +                          - add (gets the number bands)
    “ vibgyor”               - list of characters = " vibgyor"
              ṁ              - mould like the result above (as a range)
               µ             - start a new monadic chain
                 J           - range of length
                ṫ            - tail (vectorises) (gets the suffixes)
                  Z          - transpose
                   z⁶        - transpose with filler space character
                             -   (together these pad with spaces to the right)
                     U       - reverse each
                             -   (now we have the left side of the rainbow upside down)
                        ⁸    - chain's left argument, as right argument of...
                       "     -   zip with:
                      ;      -     concatenation
                             -   (adds the central character)
                         ŒB  - bounce (vectorises at depth 1)
                             -   (reflects each row like [1,2,3,4] -> [1,2,3,4,3,2,1])
                           Ṛ - reverse (turn the rainbow up the right way)

2

आर , 130 बाइट्स

function(n,k=n%/%7*8+1+n%%7,a=el(strsplit(' vibgyor'/k,'')))for(i in k:1)cat(d<-' '/(i-1),a[c(k:i,i,i:k)],d,sep='','
')
"/"=strrep

इसे ऑनलाइन आज़माएं!

  • -6 बाइट्स @JayCe को धन्यवाद


@ जयके: धन्यवाद! अद्यतन और upvoted!
डाइजेक्सिल

2

हास्केल , 106 113 बाइट्स

मैं अभी तक अन्य पोस्ट (अर्थात् यह ) टिप्पणी नहीं कर सकता, इसलिए मुझे एक अलग उत्तर के रूप में समाधान पोस्ट करना होगा।

अंडाणुओं द्वारा 7 बाइट्स दूर गोल्फ

p x=reverse x++x!!0:x
u m|n<-m+div(m-1)7=[(' '<$[z..n])++p(drop(n-z)$take(n+1)$cycle" vibgyor")|z<-[0..n]]

इसे ऑनलाइन आज़माएं!

( पुराना संस्करण , 113 बाइट्स)


अच्छा जवाब। मैं हास्केल नहीं जानता, लेकिन कोड अन्य हास्केल जवाब से अलग लगता है। पुनश्च: @ नमामी की टिप्पणी में गोल्फ-सुझावों के बाद हास्केल का अन्य उत्तर वास्तव में 110 बाइट्स है । भले ही, यह एक अच्छा वैकल्पिक हास्केल उत्तर है, इसलिए मेरी ओर से +1।
केविन क्रूज़सेन

1
ऐसा लगता है कि सूची की समझ इस चुनौती का बेहतर साधन थी। मैं कुल फ़ंक्शन को घटाकर 106 बाइट्स के लिए आपके समाधान को गोल्फ करने में सक्षम था । इन परिवर्तनों के अनुकूल होने के लिए स्वतंत्र महसूस करें।
ओव्स

2

पॉवरशेल , 108 98 89 85 बाइट्स

param($x)($x+=$x/7-replace'\..*')..0|%{' '*$_+-join(" vibgyor"*$x)[$x..$_+$_+$_..$x]}

इसे ऑनलाइन आज़माएं!

यह अब बहुत ठीक लगता है। बैंकर की गोलाई अभी भी शैतान है और मुझे पता चला है कि कैसे एक गैर-गूंगा में शामिल होना है। मैंने ज्यादा सफलता नहीं पाने के लिए $ s के साथ बंदर करने की कोशिश की। बोलते हुए, बिना परिणाम के परिणाम बहुत अच्छे लगते हैं, थोड़ी उदासी:

         vvv
        v     v
       v   rrr   v
      v   r ooo r   v
     v   r o yyy o r   v
    v   r o y ggg y o r   v
   v   r o y g bbb g y o r   v
  v   r o y g b iii b g y o r   v
 v   r o y g b i vvv i b g y o r   v
v   r o y g b i v     v i b g y o r   v

[int] $ x + = $ x / +?
माज़ी

@mazzy जो x = 25 के लिए विफल रहता है। आपको ट्रंकेट करना होगा लेकिन इंट राउंड में कास्टिंग करना होगा
Veskah

हाँ। और truncate काम करता है
mazzy

1
@ mazzy मुझे पता है, मेरे द्वारा छांटने के एकमात्र तरीके या तो [गणित] :: truncate () या ऊपर प्रयोग किए गए रेगेक्स ट्रिक हैं। [int] $ x संख्या को गोल करता है। यदि आप एक बेहतर तरीका जानते हैं, मैं सभी कान हूँ।
Veskah

1

पायथन 2 , 132 131 बाइट्स

def f(n):
 t=n+n/7;s=('vibgyor '*n)[:t];r=[s[~i:]+t*' 'for i in range(t)]
 for l in zip(*r+3*[' '+s]+r[::-1])[::-1]:print''.join(l)

इसे ऑनलाइन आज़माएं!


बचाया:

  • -1 बाइट, जोनाथन फ्रेच को धन्यवाद

//पायथन 2 में क्यों ?
जोनाथन फ्रीच

@JonathanFrech क्योंकि मैं गूंगा हूं: P
TFeld

@ दज़िमा, हाँ। अब तय किया जाना चाहिए
TFeld

1

लाल , 153 बाइट्स

func[n][r: take/last/part append/dup copy"""roygbiv "n l: 9 * n + 8 / 8
repeat i l[print rejoin[t: pad/left take/part copy r i l last t reverse copy t]]]

इसे ऑनलाइन आज़माएं!

थोड़ा अधिक पठनीय:

f: func[ n ] [
    r: copy ""
    append/dup r "roygbiv " n
    r: take/last/part r l: 9 * n + 8 / 8
    repeat i l [
        print rejoin [ t: pad/left take/part copy r i l
                       last t 
                       reverse copy t ]
    ]
]

1

जावा (JDK 10) , 184 बाइट्स

n->{int h=n+n/7,i=h+1,w=i*2+1,j,k=0;var o=new char[i][w];for(;i-->0;o[i][w/2]=o[i][w/2+1])for(j=w/2;j-->0;)o[i][j]=o[i][w+~j]=i<h?j<1?32:o[i+1][j-1]:" vibgyor".charAt(k++%8);return o;}

इसे ऑनलाइन आज़माएं!

7 में से प्रत्येक के लिए एक अतिरिक्त अग्रणी और अनुगामी स्थान प्रिंट करता है।

व्याख्या

n->{                             // IntFunction
 int h=n+n/7,                    //  Declare that height = n + n/7
     i=h+1,                      //          that index  = h + 1
     w=i*2+1,                    //          that width  = (h+1)*2+1
     j,                          //          j
     k=0;                        //          that k      = 0
 var o=new char[i][w];           //  Declare a 2D char array
 for(;                           //  Loop
   i-->0;                        //    Until i is 0
   o[i][w/2]=o[i][w/2+1]         //    After each run, copy the middle letter.
 )
  for(j=w/2;                     //   Loop on j = w/2
   j-->0;                        //     Until j = 0
  )                              //
   o[i][j]                       //    copy letters to the left side,
    =o[i][w+~j]                  //      and the right side
    =i<h                         //      if it's not the last line
     ?j<1                        //        if it's the first (and last) character
      ?32                        //          set it to a space.
      :o[i+1][j-1]               //          else set it to the previous character on the next line.
     :" vibgyor".charAt(k++%8);  //      else assign the next letter.
 return o;                       //  return everything
}

क्रेडिट


आप को बदलने के द्वारा 2 बाइट्स बचा सकते हैं ,w=-~h*2+1,i=h+1करने के लिए,i=h+1,w=i*2+1
केविन Cruijssen

वाह, मुझे सच में आधी रात को गोल्फ नहीं गुजारनी चाहिए थी! इसके लिए धन्यवाद, @ केविनक्रूजसेन! :)
ओलिवियर ग्रेगोइरे

i-~iइसके बजाय सुझावi*2+1
सीताफल

1

स्टैक्स , 23 बाइट्स

⌡G'5h!M╩EV[Ez ▼>≈<S⌡⌡0`

इसे चलाएं और डीबग करें

अनपैक्ड, अनगुल्फेड और टिप्पणी की गई, यह इस तरह दिखता है।

" vibgyor"  string literal
,8*7/^      input * 8 / 7 + 1
:m          repeat literal to that length
|]          get all prefixes
Mr          rectangularize, transpose array of arrays, then reverse
            this is the same as rotating counter-clockwise
m           map over each row with the rest of the program, then implicitly output
            the stack starts with just the row itself
  _h        push the first character of the row
  _r        push the reversed row
  L         wrap the entire stack in a single array

इसको चलाओ

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.