संभव डुप्लिकेट:
Generating all Possible Combinationsएन-एन्यूमेरबल्स LINQ स्टेटमेंट में?
मुझे यकीन है कि नहीं कर रहा हूँ कैसे वाक्यांश सवाल करने के लिए; लेकिन मैं एक मूर्ख तर्क पहेली पर काम कर रहा था कि मैं LINQ कथन का उपयोग करके हल करने में सक्षम था। प्रासंगिक कोड इस तरह देखा:
(from myA in Enumerable.Range(1, 40)
from myB in Enumerable.Range(1, 40)
from myC in Enumerable.Range(1, 40)
from myD in Enumerable.Range(1, 40)
where myA + myB + myC + myD == 40
&& myA <= myB
&& myB <= myC
&& myC <= myD
select new[] {myA, myB, myC, myD})
तो यह मूल रूप से है कि कहाँ खंड में मानदंडों को पूरा ए, बी, सी डी के सभी संयोजनों पैदा कर रहा है।
जो मैं अभी करने की कोशिश कर रहा हूं वह इसे सामान्यीकृत कर रहा है, इसलिए मैं केवल चार की बजाय एन मानों के साथ एक ही चीज़ कर सकता हूं। उदाहरण के लिए, 3 मूल्यों के साथ - बराबर कोड होगा:
(from myA in Enumerable.Range(1, 40)
from myB in Enumerable.Range(1, 40)
from myC in Enumerable.Range(1, 40)
where myA + myB + myC == 40
&& myA <= myB
&& myB <= myC
select new[] {myA, myB, myC})
स्वाभाविक रूप से, मैं कोड को संशोधित नहीं करना चाहते - मैं एक समारोह है कि मैं फोन और एक पूर्णांक प्रदान करते हैं और यह सही वापसी की है सकते हैं वस्तु।
मैंने कुछ भ्रमित प्रयास किए हैं; लेकिन मैं वास्तव में ऐसा नहीं देख सकता कि ऐसा कुछ कैसे करें। क्या कोई मुझे सही दिशा दिखा सकता है?
एरिक Lippert (http://blogs.msdn.com/b/ericlippert/archive/2010/06/28/computing-a-cartesian- [इस पर भी ब्लॉग] उत्पाद-साथ-linq.aspx) कई अनुक्रमों के उत्पादों की गणना करने के संबंध में। यह मदद कर सकता है। –
@ एंथनी पेगम - यह सही है। वास्तव में मैं क्या देख रहा हूँ। यदि आप इसे उत्तर के रूप में पोस्ट करना चाहते हैं, तो मैं इसे स्वीकार करूंगा। –
यह * मेरा * उत्तर नहीं है। ;) यदि आप क्रेडिट देना चाहते हैं तो क्रेडिट देना चाहते हैं, [यहां आज़माएं] (http://stackoverflow.com/a/3098381/414076) –