C भाषा round फंक्शनको पूर्ण व्याख्या|राउन्डिङको आधारभूतदेखि उन्नत प्रयोगसम्म

目次

1. परिचय: C भाषा मा गोलाई गर्ने तरिका के हो?

C भाषा मा संख्यात्मक प्रक्रिया मा अपरिहार्य 「गोलाई」 को विचार

प्रोग्रामिङमा, दशमलवलाई गोलाई गरेर पूर्णांकमा रूपान्तरण गर्ने प्रक्रिया विभिन्न परिस्थितिहरूमा आवश्यक पर्छ। उदाहरणका लागि, रकम गणना गर्दा 「१ येन भन्दा कमलाई काट्ने」 वा 「सबैभन्दा नजिकको पूर्णांकमा गोलाई गर्ने」 जस्ता प्रक्रिया आवश्यक हुन्छ। विशेष गरी C भाषा मा, डेटा लाई प्रभावकारी र सही तरिकाले ह्यान्डल गर्न, यस प्रकारको 「गोलाई प्रक्रिया」 को बुझाइ अत्यन्त महत्वपूर्ण छ।

C भाषामा यस उद्देश्यका लागि तयार गरिएको round फङ्सन छ, यसलाई प्रयोग गर्दा सजिलै गोलाई गर्न सकिन्छ।

round फङ्सन के हो? कहिले प्रयोग गर्ने

round फङ्सन हो, आर्ग्युमेन्टको रूपमा दिइएको फ्लोटिङ पोइन्ट नम्बरलाई सबैभन्दा नजिकको पूर्णांकमा गोलाई गर्ने मानक लाइब्रेरी फङ्सन हो। उदाहरणका लागि, round(2.3) ले 2 फिर्ता गर्छ, र round(2.7) ले 3 फिर्ता गर्छ। दशमलव पहिलो अंक ठीक 0.5 भएमा, साइन अनुसार「परम मान ठूलो दिशामा」 गोलाई गर्ने विशेषता पनि छ।

round(2.5);   // → 3.0
round(-2.5);  // → -3.0

यसरी, धनात्मक सङ्ख्या मात्र नभई ऋणात्मक सङ्ख्याको गोलाई पनि समर्थन गर्दछ, वित्तीय गणना, ग्राफको स्केल प्रोसेस, सांख्यिकीय विश्लेषण आदि धेरै प्रयोगहरूमा प्रयोग हुन्छ।

C99 पछि उपलब्ध सुविधाहरू

तर ध्यान दिनु पर्ने कुरा के भने, round फङ्सन C99 मानक पछि परिचय गरिएको फङ्सन हो। अर्थात, पुरानो C कम्पाइलरमा समर्थन नहुन सक्छ, त्यसैले प्रयोग वातावरण अनुसार वैकल्पिक उपाय विचार गर्न आवश्यक छ।

त्यसैले, यस लेखमा तलका बिषयहरूलाई समेट्दै, C भाषा मा गोलाई प्रक्रिया लाई समग्र रूपमा व्याख्या गर्नेछौं।

  • round फङ्सनको मूल संरचना र प्रयोग विधि
  • दशमलव तल n अंकमा गोलाई गर्ने तरिका
  • फङ्सन प्रयोग नगरी म्यानुअल गोलाई गर्ने तरिका
  • roundfloor तथा ceil बीचको भिन्नता
  • प्रायः हुने त्रुटिहरू र तिनीहरूको समाधान
  • शुरु गर्नेहरूका लागि अड्किने बिन्दुहरूको FAQ

C भाषा मा सही र सुरक्षित रूपमा गोलाई प्रक्रिया गर्न आवश्यक ज्ञानलाई, कृपया यस लेख मार्फत हासिल गर्नुहोस्।

2. 【आधार】round फलनको प्रयोग र मूल संरचना

round फलनको सारांश र प्रयोग

round फलनले, फ्लोटिङ पोइन्ट संख्यालाई सबैभन्दा नजिकको पूर्णांकमा गोलाई गर्नेका लागि मानक पुस्तकालय फलन हो। उदाहरणका लागि, वास्तविक संख्याको गणना परिणामलाई प्रदर्शनको लागि गोलाई गर्न चाहँदा वा त्रुटि घटाएर डेटा प्रक्रिया गर्न चाहँदा प्रयोग गरिन्छ।round C99 पछि मानकमा समावेश छ, र math.h हेडर फाइलमा परिभाषित छ।

यो फलनले, आर्गुमेन्टको रूपमा double प्रकारको संख्या लिन्छ, र परिणाम पनि double प्रकारमा फर्काउँछ।

मूल संरचना र प्रयोग

#include <math.h>

double round(double x);
  • x: गोलाई गर्न चाहिने फ्लोटिङ पोइन्ट संख्या(double型)
  • फिर्ती मान: सबैभन्दा नजिकको पूर्णांकमा गोलाई गरिएको मान(double型)

यो फलनले「0.5 भन्दा माथिको भागलाई माथि गोलाई, 0.5 भन्दा कमलाई तल गोलाई」भनेको व्यवहार गर्दछ। ध्यान दिनु पर्ने कुरा, ठीक 0.5 भएको अवस्थामा, absolute मान ठूलो दिशातिर (अर्थात् “दूरको दिशा”) गोलाई गर्ने भन्ने विशिष्टता हो।

उदाहरण प्रयोग: round फलनको कार्य परिणाम जाँच

तलको कोड वास्तविकमा round फलन प्रयोग गरेर बनाइएको सरल प्रोग्राम हो।

#include <stdio.h>
#include <math.h>

int main() {
    double a = 2.3;
    double b = 2.5;
    double c = -2.3;
    double d = -2.5;

    printf("round(2.3) = %.0f
", round(a));
    printf("round(2.5) = %.0f
", round(b));
    printf("round(-2.3) = %.0f
", round(c));
    printf("round(-2.5) = %.0f
", round(d));

    return 0;
}

कार्य परिणाम:

round(2.3) = 2
round(2.5) = 3
round(-2.3) = -2
round(-2.5) = -3

दशमलव पहिलो अंक 0.5 हुँदा कार्यमा ध्यान दिनुहोस्

उपरोक्त उदाहरण जस्तै, 2.5 लाई 3 मा, -2.5 लाई -3 मा गोलाई गरिन्छ। यो कारण, round फलनले 「दूरको दिशातिर गोलाई(away from zero)」 नियमलाई अनुसरण गर्दछ। गणितीय रूपमा भन्नुपर्दा “सम संख्या तिर गोलाई” होइन, “सधैँ माथि वा तल तिर टाढा जाने दिशा” मा प्रक्रिया हुन्छ, कृपया ध्यान दिनुहोस्।

कम्पाइल गर्दा ध्यान दिनु पर्ने बुँदाहरू

round फलन प्रयोग गर्दा, तलका 2 बुँदाहरू जाँच गरौं।

  1. math.h लाई बिर्सनु नहोस् इन्क्लुड गर्नुहोस्
  2. कम्पाइलरले C99 पछि समर्थन गरेको छ भन्ने कुरा
  • gcc प्रयोग गरिरहनु भएको छ भने, स्पष्ट रूपमा C99 मानक अनुसार कम्पाइल गर्नुहोस्
gcc -std=c99 sample.c -lm

-lm math पुस्तकालयको लिंक निर्दिष्ट हो। बिर्सिएमा「अपरिभाषित सन्दर्भ」त्रुटि हुनेछ।

年収訴求

3. दशमलव तल n अंकमा गोलाई गर्ने तरिका(अनुप्रयोग प्रविधि)

C Gengo को round kansū पूर्णांकमा गोलाई गर्ने आधार हो

C Gengo को round kansū ले、सबैभन्दा नजिकको पूर्णांकमा गोलाई गर्न सक्दछ, तर、दशमलव तलको इच्छित अंक संख्यामा प्रत्यक्ष रूपमा गोलाई गर्ने कार्य छैन। तर, संख्यालाई अस्थायी रूपमा विस्तार गरेरround प्रयोग गरेर, फेरि सानो बनाइ, इच्छित अंक संख्यामा गोलाई गर्ने प्रक्रिया कार्यान्वयन गर्न सकिन्छ।

दशमलव n अंकमा गोलाई गर्ने तरिकाको विचार

निम्न चरणहरू अनुसार प्रक्रिया गरिन्छ:

  1. मूल संख्यालाई 10 को n घात ले गुणा गरेर विस्तार गर्नुहोस्
  2. round kansū ले गोलाई गर्नुहोस्
  3. 10 को n घात ले भाग गरेर मूलमा फर्काउनुहोस्

उदाहरणका लागि, दशमलव दोस्रो अंक(अर्थात् 0.01 को अंक)मा गोलाई गर्न चाहनुहुन्छ भने、100 गुणा → गोलाई → 100 ले भाग गर्ने भन्ने क्रम हुन्छ।

कार्यान्वयन उदाहरण:दशमलव तल 2 अंकमा गोलाई

#include <stdio.h>
#include <math.h>

int main() {
    double value = 123.45678;
    double result = round(value * 100) / 100;

    printf("मूल्य: %.5f\n", value);
    printf("दशमलवको 2 अङ्कसम्म गोल गरिएको मूल्य: %.2f\n", result);

    return 0;
}

आउटपुट परिणाम:

मूल्य: 123.45678
दशमलवको 2 अंकसम्म गोल गरिएको मूल्य: 123.46

यसरी, इच्छित अंकमा गोलाई सम्भव हुन्छ।

pow kansū प्रयोग गरेर गतिशील रूपमा अंक संख्या निर्दिष्ट गर्नुहोस्

बहु-अंक संख्यालाई समर्थन गर्न चाहनुहुन्छ भने、pow kansū प्रयोग गरेर गतिशील रूपमा 10 को n घात गणना गर्न सकिन्छ।

#include <stdio.h>
#include <math.h>

double round_to_n_digits(double value, int n) {
    double scale = pow(10, n);
    return round(value * scale) / scale;
}

int main() {
    double num = 98.7654321;
    printf("3 अङ्कसम्म गोलाकार: %.3f
", round_to_n_digits(num, 3));
    printf("1 अङ्कसम्म गोलाकार: %.1f
", round_to_n_digits(num, 1));
    return 0;
}

परिणाम:

3 अंकसम्म गोलाकार गर्नुहोस्: 98.765
1 अंकसम्म गोलाकार गर्नुहोस्: 98.8

यसरी, लचिलो कार्यको रूपमा पुन: प्रयोग गर्न सकिने रूपले लेखेर, व्यावहारिक कोड बनाइन्छ।

ध्यान दिनुहोस्:फ्लोटिङ पोइन्टको शुद्धता त्रुटि

फ्लोटिङ पोइन्ट गणनामा、आन्तरिक रूपमा त्रुटि उत्पन्न हुन सक्छ। उदाहरणका लागि、round(1.005 * 100) / 100 ले1.00 हुन सक्छ(आदर्श1.01)。 योद्विआधारी प्रतिनिधित्व त्रुटि द्वारा हो।

त्यसैले, शुद्धता अत्यन्त महत्वपूर्ण प्रक्रिया(उदाहरण:वित्तीय・सांख्यिकीय आदि)मा, अंक समायोजन पछिदशमलव n+1 अंक समेत समावेश गर्ने शुद्धता जाँच गर्न जस्ता उपाय आवश्यक हुन्छ।

4. float प्रकारसँग मिल्दो roundf कार्य र भिन्नता

C भाषा मा प्रकार अनुसार कार्यहरू उपलब्ध छन्

C भाषा मा, डेटा प्रकार अनुसार विभिन्न गोलाइ कार्यहरू उपलब्ध छन्।round कार्यले double प्रकारको सङ्ख्यालाई आर्गुमेन्टको रूपमा लिन्छ, र double प्रकारको नतिजा फिर्ता गर्छ भन्ने आधारभूत हो। तर, float प्रकार र long double प्रकारलाई पनि समर्थन गर्न, प्रत्येकको लागि विशेष कार्यहरू मानक पुस्तकालयमा समावेश छन्।

round / roundf / roundl को भिन्नता

तल जस्तै, प्रयोग गर्ने कार्यलाई ह्यान्डल गर्ने सङ्ख्याको प्रकार अनुसार विभाजन गरिन्छ:

कार्यको नामआर्गुमेन्टको प्रकारफिर्ता मानको प्रकारसम्बन्धित प्रकार
rounddoubledoubleसामान्य दोहोरो-प्रेसिजन फ्लोटिङ पोइन्ट
roundffloatfloatएकल-प्रेसिजन फ्लोटिङ पोइन्ट
roundllong doublelong doubleविस्तारित प्रेसिजन फ्लोटिङ पोइन्ट

यसरी,सङ्ख्याको प्रेसिजन अनुसार उपयुक्त कार्य चयन गर्नु C भाषा मा अत्यन्त महत्वपूर्ण छ

किन float प्रकारमा roundf प्रयोग गर्नु आवश्यक छ?

float प्रकारको भेरिएबललाईround द्वारा गोलाइ गर्दा,आन्तरिक रूपमा double प्रकारमा अस्पष्ट प्रकार रूपान्तरण हुन्छ कारणले प्रदर्शनको गिरावट वा अनपेक्षितुटिको कारण हुन सक्छ।

विशेष गरी एम्बेडेड विकास वा ठूलो गणना गर्ने प्रोग्रामहरूमा,प्रयोग गर्ने प्रकारलाई सही मिलाएर, प्रक्रिया गति र मेमोरी दक्षता सुधार गर्न सकिन्छ।

roundf कार्यको प्रयोग उदाहरण

#include <stdio.h>
#include <math.h>

int main() {
    float f = 3.14f;
    float result = roundf(f);

    printf("roundf(3.14f) = %.0f
", result);
    return 0;
}

आउटपुट नतिजा:

roundf(3.14f) = 3

यसरी,float प्रकारलाई ह्यान्डल गर्दा,अनिवार्य रूपमाroundf कार्य प्रयोग गरेर, अधिक शुद्ध र प्रभावकारी प्रक्रिया प्राप्त गर्न सकिन्छ।

सामान्य चयन मार्गदर्शन

  • float प्रकार प्रयोग गरिरहनु भएको छ भनेroundf
  • double प्रकार मूल (मानक फ्लोटिङ नम्बर)round
  • उच्च प्रेसिजन गणना चाहनुहुन्छ भनेroundl

उपयुक्त कार्य विभाजन गरेर,प्रोग्रामको गुणस्तर·गति·रखरखाव क्षमता बढाउन सकिन्छ।

5. Function न प्रयोग गर्ने गोलाई प्रक्रिया(आफै बनाएको प्रक्रिया)

लाइब्रेरी function न प्रयोग गरेर गोलाई गर्ने तरिका

सी भाषामा,standard library कोround function लाई प्रयोग गर्न नसक्ने वातावरण(उदाहरण:C89 मानकको पुरानो कम्पाइलर वा एम्बेडेड वातावरण)वा,जानाजानी निर्भरता टार्न चाहिने अवस्थामा,आफै बनाएको गोलाई प्रक्रिया लेख्नु आवश्यक पर्छ।

सबैभन्दा आधारभूत तरिका भनेको,0.5 लाई थपेर पूर्णांक प्रकारमा कास्ट गर्ने हो।

धनात्मक संख्यालाई गोलाई गर्ने सरल तरिका

#include <stdio.h>

int main() {
    double num = 2.7;
    int result = (int)(num + 0.5);
    printf("राउन्ड गरिएको नतिजा: %d
", result);
    return 0;
}

यो तरिकामा,2.7 मा0.5 थपेर3.2 बनाइन्छ, त्यसलाईint मा कास्ट गरेर3 बनाइँदा,पूर्णांकमा गोलाई प्राप्त हुन्छ।

नकारात्मक संख्यामा अनपेक्षित नतिजा आउन सक्छ

यो तरिकाधनात्मक संख्यामा सही रूपमा काम गर्छ, तरनकारात्मक संख्यामा गलत नतिजा दिन सक्छ, त्यसैले सावधान रहनु आवश्यक छ।

#include <stdio.h>

int main() {
    double num = -2.7;
    int result = (int)(num + 0.5);
    printf("राउन्डिङ परिणाम: %d
", result);
    return 0;
}

यस अवस्थामा,-2.7 + 0.5 = -2.2int मा कास्ट गर्दा-2 हुन्छ, तरगणितीय रूपमा-3 नै सही गोलाई नतिजा हो।
अर्थात,यो तरिकाले नकारात्मक संख्यालाई सही रूपमा प्रक्रिया गर्न सक्दैन भन्ने कमजोरी छ।

नकारात्मक संख्यालाई सम्हाल्ने गोलाई प्रक्रिया(सुधारित संस्करण)

नकारात्मक मानलाई पनि सम्हाल्न चाहनुहुन्छ भने, संकेत जाँच गरी प्रक्रिया विभाजन गर्नु सुरक्षित हुन्छ।

#include <stdio.h>

int round_manual(double x) {
    if (x >= 0) {
        return (int)(x + 0.5);
    } else {
        return (int)(x - 0.5);
    }
}

int main() {
    printf("round_manual(2.5) = %d
", round_manual(2.5));   // → 3
    printf("round_manual(-2.5) = %d
", round_manual(-2.5)); // → -3
    return 0;
}

यसरी,नकारात्मक संख्यामा 0.5 लाई “घटाएर” गर्दा,standardround function जस्तै व्यवहार पुन: निर्माण गर्न सकिन्छ।

Function न प्रयोग गर्ने तरिकाको फाइदा र सीमाहरू

फाइदा:

  • math.h मा निर्भर नहुनाले, हल्का र पोर्टेबलिटी उच्च छ
  • एम्बेडेड वातावरण र पुराना मानकमा पनि प्रयोग गर्न सकिन्छ

सीमा:

  • उच्च सटीकता वाला दशमलव(double प्रकार)को ह्यान्डलिंगमा सावधानी आवश्यक
  • गोलाई प्रक्रियाको कडाइ आवश्यक परेमा उपयुक्त छैन
  • गणना विधि आफैँ बुझ्न आवश्यक छ

व्यावहारिक रूपमा round function को प्रयोग सिफारिस

यस्ता म्यानुअल प्रक्रिया पनि परिस्थितिमा उपयोगी हुन सक्छ,सटीकता・मर्मतयोग्यता・पुनरुत्पादनको दृष्टिले, standard library कोround function वाroundf function प्रयोग गर्नु मूल नीति हो। यो केवल「लाइब्रेरी प्रयोग गर्न नसक्ने स्थितिमा वैकल्पिक उपाय」को रूपमा बुझ्नुपर्छ।

6. round function ra anya rounding function haruko antar (floor, ceil sanga tulana)

C gengo ma anek “marume” function haru upalabdha chan

C gengo ma, round function ko alawa, floor (truncate) ra ceil (round up) jasta marume system ko function haru standard library math.h ma upalabdha chan. Yiharu sabai floating-point sankhya haru lai integer disha ma parivartan garna ko lagi ko function haru hun, tara, marume ko disha alag-alag hune karan, upayukta prayog bhinna garna mahatwapurna cha.

Pratyek function ko antar lai talika ma byabasthit garnu

Function nameDescriptionExample (2.7)Example (-2.7)
roundRound to the nearest integer3-3
floorTruncate towards smaller direction2-3
ceilRound up towards larger direction3-2

round le “0.5” ko samaya, sign anusar dur ko taraf marume garchha bhanne specification ho.

Pratyek function ko byaktik prayog udaharan

#include <stdio.h>
#include <math.h>

int main() {
    double num = -2.7;

    printf("round(-2.7) = %.0f
", round(num));
    printf("floor(-2.7) = %.0f
", floor(num));
    printf("ceil(-2.7)  = %.0f
", ceil(num));

    return 0;
}

Niskashita parinaam:

round(-2.7) = -3
floor(-2.7) = -3
ceil(-2.7)  = -2

Yiharu ko antar bujhna sakina bhane, anichhahit data prakriya ra galat niskashita ko karan bann sakcha, tesaile marume ko disha ramro sanga hernu parchha.

Kuna function prayog garnu? Prayog anusar guide

Use caseSuitable functionReason
Rakam ra sankhya ko pradarshan (rounding)roundSadharan sankhya pradarshan ma upayukta
Range restriction ma ‘upper limit’ lai exceed nagarne prakriyafloorSadhai chhoto hunchha, tesaile surakshit
Array size ra loop count ko nischit garneceilSadhai paryapt maan nischit garna sakinchha

Udaharan ko lagi, product ko discount pachi ko mulya pradarshan garda round prakritik cha, tara shipping cost lai exceed nagarna ko lagi truncate garna parne awastha mafloor, page sankhya hisab garna jasto, kam se kam 1 unit nischit garna cha bhaneceil upayukta cha.

Bibhinn prayog ko mahatwa

Program le ichchha anusar chalcha ki chaina bhanne kura, ‘sankhya ko seema ma byabahaar’ ma thulo prabhav parcha. Bises gari UI ma pradarshit mulya, sankhyaatmak prakriya ko sangrah ekai, bhag prakriya ko sankhya adi ma, marume galti haru sidha functional bug ma parna sakne awastha dherai cha.

Tesaile, roundfloorceil ko antar haru yaad garne star ma bujhna parne moolbhoot gyan ho.

7. सामान्य त्रुटिहरू र समाधानहरू

C भाषा मा round फलन प्रयोग गर्दा सामान्यतया हुने गल्तीहरू

round फलन उपयोगी भएता पनि、यदि विशेष शर्तहरू पूरा नभएमा कम्पाइल त्रुटि वा गलत कार्यसम्पादन उत्पन्न हुन सक्छ। यहाँ, प्रोग्रामिङ शुरुआतीहरू र C भाषा मा अपरिचित व्यक्तिहरूले प्रायः सामना गर्ने त्रुटिहरूलाई उठाइन्छ, र तिनीहरूको कारण र समाधानहरूलाई व्याख्या गरिन्छ।

त्रुटि①:math.h लाई इन्क्लुड नगरेको

सामान्य त्रुटि सन्देश:

warning: implicit declaration of function ‘round’ [-Wimplicit-function-declaration]

यो त्रुटि तब उत्पन्न हुन्छ जब math.h लाई इन्क्लुड नगरी round फलन प्रयोग गर्ने प्रयास गरिन्छ।

समाधान:

#include <math.h>

यसलाई स्रोत फाइलको सुरुमा अनिवार्य रूपमा थप्नुहोस्। साथै, अन्य गोलाई फलनहरू(floorceil आदि) पनि समान रूपमा math.h आवश्यक पर्छ।

त्रुटि②:लिङ्क गर्दा अपरिभाषित प्रतीक

सामान्य त्रुटि सन्देश(gcc को अवस्थामा):

undefined reference to `round'

यो त्रुटि तब उत्पन्न हुन्छ जब लिङ्क गर्दा गणित पुस्तकालय(libm) निर्दिष्ट गरिएको छैन

समाधान:

कम्पाइल गर्दा -lm विकल्प थपेर समाधान गर्न सकिन्छ।

gcc sample.c -lm

-lm भनेको “math library” को संक्षिप्त रूप हो।

त्रुटि③:पुरानो C कम्पाइलरमा round फलन प्रयोग गर्न सकिँदैन

round फलन C99 पछि परिचय गरिएको फलन भएको कारण, पुरानो C89 मानकको वातावरणमा प्रयोग गर्न नसक्ने सम्भावना छ।

समाधान:

  • कम्पाइलर C99 पछि समर्थन गर्छ कि छैन जाँच गर्नुहोस्
  • यदि GCC प्रयोग गरिरहनु भएको छ भने, स्पष्ट रूपमा C99 मानक अनुसार कम्पाइल गर्नुहोस्
gcc -std=c99 sample.c -lm

यदि कसै कारण round प्रयोग गर्न सकिँदैन भने, अघिल्लो अध्यायमा परिचय गराइएको आफ्नै गोलाई फलन प्रयोग गरेर विकल्प उपलब्ध छ।

त्रुटि④:पूर्णांक प्रकारहरू बीच विभाजनले सटीकता गुमाउनु

उदाहरणका लागि, दशमलव अंकमा गोलाई गर्ने प्रक्रियामा, पूर्णांक विभाजन गरियो भने परिणाम अनपेक्षित हुन्छ।

गलत उदाहरण:

int x = 7;
int y = 2;
double result = round(x / y); // → परिणाम: 3.0 होइन 3.0 (←7/2=3 को कारण)

x / y को परिणाम पूर्णांक 3 हुन्छ, जसले दशमलव भाग गुमाउँछ।

समाधान:

कम्तिमा एउटा मानलाई double मा कास्ट गरेर गणना गर्नुहोस्।

double result = round((double)x / y);

त्रुटि⑤:प्रकार असंगतता(float प्रकारमा round प्रयोग)

float प्रकारको मानमा round प्रयोग गर्दा, स्वचालित रूपमाdouble मा उन्नत हुन्छ, अनावश्यक प्रकार रूपान्तरण हुन्छ, जसले अनपेक्षित प्रदर्शन गिरावट ल्याउन सक्छ।

समाधान:

float प्रकारको लागि roundf फलन प्रयोग गर्नुहोस्।

float f = 2.5f;
float result = roundf(f);

स्थिर कोडको लागि

उपरोक्त जस्ता त्रुटिहरू C भाषा प्रयोग गर्दाअत्यन्तै सामान्य मूलभूत गल्तीहरू हुन्, तर पूर्वज्ञानले सजिलै टाल्न सकिन्छ।उपयुक्त इन्क्लुड, कम्पाइल विकल्प, र प्रकारको सही ह्यान्डलिंग नै बग‑रहित स्थिर कोडको पहिलो कदम हो।

8. सारांश: round कार्यलाई सुरक्षित रूपमा प्रयोग गर्ने बुँदाहरू

C भाषा मा गोलाई प्रक्रिया गर्न चाहनुहुन्छ भने round कार्य मूलभूत हो

यस लेखमा, C भाषा मा गोलाई प्रक्रिया को मूलभूत रूपमा, round कार्यको प्रयोग विधि र अनुप्रयोग, सामान्य त्रुटिहरू र ध्यान दिनुपर्ने बुँदाहरू बारेमा व्याख्या गरिएको छ।

round कार्य अत्यन्त उपयोगी र शक्तिशाली उपकरण हो, तर यसको प्रभाव सही रूपमा देखाउनको लागि, कार्यको विशिष्टता र वातावरण निर्भर प्रतिबन्धहरूलाई राम्ररी बुझ्नु महत्त्वपूर्ण छ।

सुरक्षित रूपमा प्रयोग गर्नका लागि बुँदाहरू

यहाँ, लेखको सामग्रीलाई आधार बनाएर व्यावहारिक बुँदाहरू लाई पुनरावलोकन गर्छौं:

  • round कार्य C99 पछि सम्म अनुकूल छ
    प्रयोग गर्नु अघि वातावरण अनुकूल छ कि छैन जाँच गर्नु महत्त्वपूर्ण छ। पुरानो वातावरणमा प्रयोग गर्न नसक्ने सम्भावना छ।
  • math.h को इन्क्लुड र -lm को लिंक निर्दिष्ट गर्न नबिर्सनुहोस्
    यी मध्ये कुनै एक अभाव भएमा, कम्पाइल वा लिंक त्रुटि हुनेछ।
  • दशमलव तल n अंकमा गोलाई गर्नको लागि विस्तार → गोलाई → संकुचन क्रमले प्रक्रिया गर्नुहोस्
    round(value * 100) / 100 जस्तै रूपले, लचिलो गोलाई सम्भव हुन्छ।
  • डेटा प्रकार अनुसार कार्यलाई विभाजन गरी प्रयोग गर्नुहोस्
    double मा round, float मा roundf, long double मा roundl प्रयोग गरौं।
  • नकारात्मक संख्याहरूलाई ह्यान्डल गर्दा व्यवहारलाई बुझ्नु आवश्यक छ
    round(-2.5) को परिणाम -3। यो चिह्नलाई कायम राख्दै मानको ठूलो दिशामा गोलाई हुने विशिष्टता हो।
  • त्रुटि रोक्नको लागि, पूर्णांक भागफलको ह्यान्डलिंग र कास्टमा पनि ध्यान दिनुहोस्
    int / int को गणना परिणाम पूर्णांक हुन्छ, त्यसैले अपेक्षित फ्लोटिङ पोइन्ट परिणाम नआउन सक्छ।

गोलाई प्रक्रियाको महत्व

संख्यात्मक गोलाई प्रक्रिया, रकम गणना, आँकडा, ग्राफ रेखाचित्र, सेन्सर मान प्रक्रिया जस्ता विभिन्न प्रोग्रामिङ क्षेत्रहरूमा प्रयोग हुन्छ। त्यसैले, सही रूपमा काम गर्ने गोलाई प्रक्रिया चयन गरी, परिस्थितिअनुसार उपयुक्त रूपमा प्रयोग गर्नु प्रोग्रामको विश्वसनीयता र गुणस्तरलाई ठूलो प्रभाव पार्छ।

अधिक अनुप्रयोगतर्फ

यस लेखमा सिकेको सामग्रीलाई आधार बनाएर, floorceil सँगको भिन्नता बुझ्नुभयो भने, एक कदम अगाडि सँगको संख्यात्मक प्रक्रिया डिजाइन सम्भव हुन्छ। कार्य प्रयोग गर्न नसक्ने वातावरणमा पनि, आफ्नै तर्कले समाधान गर्न सकिएमा, C भाषा इन्जिनियरको क्षमता निश्चित रूपमा सुधार हुनेछ।

9. FAQ(बारम्बार सोधिने प्रश्नहरू)

Q1. round फलन प्रयोग गर्न के आवश्यक छ?

A. round फलन प्रयोग गर्न, स्रोत कोडको सुरुमा #include लेख्न आवश्यक छ। साथै, GCC जस्ता कम्पाइलर प्रयोग गर्दा, -lm विकल्प थपेर लिंक गर्दा गणित पुस्तकालय निर्दिष्ट गर्नुपर्छ।

gcc sample.c -lm

अझै, round C99 पछि परिचय गरिएको फलन हो, त्यसैले पुरानो C वातावरणमा प्रयोग गर्न नसक्ने बुँदामा पनि ध्यान दिनु आवश्यक छ।

Q2. round फलन र (int)(x + 0.5) को भिन्नता के हो?

A. सकारात्मक संख्याहरूको लागि, दुवै समान रूपमा गोलाइ हुन्छ, तर नकारात्मक संख्याहरूको प्रक्रिया फरक हुन्छ।

(int)(-2.5 + 0.5) // → -2(गलत)
round(-2.5)       // → -3(सही)

round फलनले, चिह्नलाई कायम राख्दै, निरपेक्ष मान ठूलो तिर गोलाइ (away from zero) गर्छ, जसले गणितीय रूपमा सही गोलाइ सुनिश्चित गर्दछ।

Q3. float प्रकारमा गोलाइ गर्न कसरी गर्न सकिन्छ?

A. float प्रकारको लागि विशेष फलन roundf फलन प्रयोग गर्नु उत्तम हुन्छ। round फलन प्रयोग गर्दा पनि काम गर्छ, तर भित्री रूपमा double प्रकारमा रूपान्तरण हुन्छ, जसले प्रदर्शनको दृष्टिले अप्रभावी बनाउँछ।

float f = 3.14f;
float result = roundf(f);

त्यसै गरी, long double प्रकारको लागि roundl फलन उपलब्ध छ।

Q4. roundfloor, ceil लाई कसरी प्रयोग गर्ने?

A. प्रत्येक फलनको गोलाइ दिशा फरक हुन्छ।

  • round:सबैभन्दा नजिकको पूर्णांकमा(±0.5 टाढा तिर)
  • floor:सधैं सानो दिशातिर तलको पूर्णांकमा कटौती
  • ceil:सधैं ठूलो दिशातिर माथिको पूर्णांकमा वृद्धि

प्रयोगका उदाहरणहरू:

  • round:रकमको प्रदर्शन जस्ता सामान्य गोलाइ प्रक्रिया
  • floor:सीमा नाघ्न नदिने प्रक्रिया(उदाहरण:पॉइन्ट गणना)
  • ceil:न्यूनतम ग्यारेन्टी मान सुनिश्चित गर्ने प्रक्रिया(उदाहरण:पृष्ठ संख्या गणना)

Q5. round फलनलाई सुरक्षित रूपमा प्रयोग गर्नका लागि ध्यान दिनुपर्ने बुँदाहरू छन्?

A. मुख्यतया तलका बुँदाहरूमा ध्यान दिनुहोस्:

  • math.h लाई अनिवार्य रूपमा इन्क्लुड गर्नुहोस्
  • -lm विकल्पसँग लिंक गर्नुहोस्(GCC आदि)
  • प्रयोग गर्ने वातावरण C99 पछि हो भन्ने पुष्टि गर्नुहोस्
  • नकारात्मक संख्याहरूको व्यवहार बुझ्नुहोस्
  • फ्लोटिङ पोइन्ट सटीकताको त्रुटि विचार गर्नुहोस्(विशेष गरी n-औं दशमलव स्थानमा गोलाइ गर्दा)

यी बुँदाहरूलाई ध्यानमा राखेर、round फलनलाई अझ सुरक्षित・निश्चित रूपमा प्रयोग गर्न सकिन्छ।