वर्गों के संबंध में अनाज की संख्या की गणना करने के लिए मेरे पास यह सरल कार्यक्रम है:

#include "library/std_lib_facilities.h"

/*There is an old story that the emperor wanted to thank the inventor of the game of chess and asked the inventor to name
his reward. The inventor asked for one grain of rice for the first square, 2 for the second, 4 for the third, and so on,
doubling for each of the 64 squares. That may sound modest, but there wasn’t that much rice in the empire! Write a
program to calculate how many squares are required to give the inventor at least 1000 grains of rice, at least 1,000,000
grains, and at least 1,000,000,000 grains.*/

int main()
{
    int grains = 1;
    int squares = 1; 

    while(grains < 1000) {
        squares++;
        grains *=2;
        cout << grains << " rice grains for " << squares << " squares" << '\n';
    }
    return 0;
}

लूप प्रत्येक लूप के बाद अनाज और वर्ग को प्रिंट करता है। यह टर्मिनल में आउटपुट है:

2 rice grains for 2 squares
4 rice grains for 3 squares
8 rice grains for 4 squares
16 rice grains for 5 squares
32 rice grains for 6 squares
64 rice grains for 7 squares
128 rice grains for 8 squares
256 rice grains for 9 squares
512 rice grains for 10 squares
1024 rice grains for 11 squares

जैसा कि आप देख सकते हैं, लूप टर्मिनेशन, टर्मिनेशन कंडीशन से अधिक है जो grain < 1000 पर सेट है।

मुझे परिणाम के साथ कोई समस्या नहीं है, मैं सिर्फ यह जानना चाहता हूं कि लूप टर्मिनेशन मानदंड से अधिक क्यों है, यह 512 अनाज पर क्यों नहीं रुका? क्या यह लूप बॉडी में वर्गों की पुनरावृत्ति के कारण है?

0
Onome Sotu 18 मार्च 2017, 12:04
2
समाप्ति की स्थिति का परीक्षण केवल तभी किया जाता है जब निष्पादन लूप की शुरुआत में आता है - लूप में प्रत्येक कथन के बाद नहीं
 – 
M.M
18 मार्च 2017, 12:06

1 उत्तर

सबसे बढ़िया उत्तर

चूंकि

 while(grains < 1000) {  //when grain value is 512, which is true.
        squares++;
        grains *=2;  //become 1024
        cout << grains << " rice grains for " << squares << " squares" << '\n';
    }

इसके बजाय, आप अपनी समय की स्थिति को while(squares < 10) में बदल सकते हैं

या

int grains = 2;
int squares = 2; 
while(grains < 1000) {  //when grain value is 1024, which is false.
            cout << grains << " rice grains for " << squares << " squares" << '\n';
            grains *=2;
            squares++;

        }
2
Ravi 18 मार्च 2017, 12:13
धन्यवाद। यह अब बहुत स्पष्ट है। मुझे पहला उदाहरण पसंद है, यह बेहतर तरीके से बताता है कि लूप कैसे काम करता है।
 – 
Onome Sotu
18 मार्च 2017, 12:16
मैं चाहता था, लेकिन यह मुझे समय की पाबंदी देता है। इतने मिनट आदि में उत्तर स्वीकार नहीं कर सकते।
 – 
Onome Sotu
18 मार्च 2017, 12:18