1. परिचय
C भाषा उच्च गति र प्रभावकारी कार्यक्रमहरू निर्माण गर्न सक्षम भएको कारण, प्रणाली विकास र एम्बेडेड उपकरणहरू जस्ता विभिन्न क्षेत्रहरूमा प्रयोग गरिन्छ। यस लेखमा, C भाषा प्रयोग गरेर “प्राइम नम्बर पहिचान” को कार्यान्वयन विधि बारे विस्तृत रूपमा व्याख्या गर्नेछौं।
प्राइम नम्बर भनेको 1 र आफैँको संख्या बाहेक कुनै पनि सकारात्मक भाजक नहुनु हो। उदाहरणका लागि, 2, 3, 5, 7 प्राइम नम्बर हुन्, तर 4 वा 6 प्राइम नम्बर होइनन्। प्राइम नम्बरहरू एन्क्रिप्शन प्रविधि र गणितीय समस्याहरूको समाधानमा महत्वपूर्ण भूमिका खेल्छन्।
यस लेखमा, C भाषा प्रयोग गरेर प्राइम नम्बर पहिचान गर्ने आधारभूत कार्यक्रम बनाउने तरिकाबाट सुरु गरी, अझ प्रभावकारी एल्गोरिदमसम्मलाई स्पष्ट रूपमा व्याख्या गर्नेछौं। प्रोग्रामिङ शुरुआतीदेखि मध्यवर्ती स्तरसम्मका पाठकहरूलाई लक्षित गरिएको छ, त्यसैले कृपया अन्त्यसम्म पढ्नुहोस्।
2. अभाज्य संख्या के हो
अभाज्य संख्याको परिभाषा
अभाज्य संख्या (Prime Number) भनेको 1 ठूलो प्राकृतिक संख्या मध्ये, 1 र त्यो संख्यै बाहेक कुनै अन्य भाजक नहुनु हो।
अभाज्य संख्याका उदाहरणहरू
तलमा साना अभाज्य संख्याका उदाहरणहरू छन्:
- 2, 3, 5, 7, 11, 13, 17, 19, 23, 29
विशेष गरी ध्यान दिनु पर्ने कुरा भनेको 2 मात्र एकमात्र सम अभाज्य संख्या हो। बाँकी सबै अभाज्य संख्याहरू विषम हुन्।
अभाज्य संख्याहरू किन महत्वपूर्ण छन्
अभाज्य संख्याहरू केवल गणितीय रूपमा महत्वपूर्ण अवधारणा मात्र होइन, कम्प्युटर विज्ञान र इन्क्रिप्शन प्रविधिमा पनि व्यापक रूपमा प्रयोग हुन्छन्। विशेष गरी इन्क्रिप्शन एल्गोरिदमहरूमा, ठूलो अभाज्य संख्याहरू प्रयोग गरेर बनाइएका सुरक्षा प्रणालीहरू व्यापक रूपमा प्रयोग गरिन्छ।
अभाज्य संख्याहरू र C भाषा बीचको सम्बन्ध
C भाषामा, पूर्णांक गणना र कार्यक्षम प्रक्रिया सम्भव भएकाले, ठूलो मात्रामा डेटा ह्यान्डल गर्ने अभाज्य संख्या जाँच कार्यक्रमहरूका लागि उपयुक्त छ। अर्को भागमा, C भाषा प्रयोग गरेर विशिष्ट अभाज्य संख्या जाँच विधि बारे व्याख्या गरिनेछ।
3. सी भाषामा अभाज्य संख्या निर्धारण विधि
मूलभूत एल्गोरिदम
अभाज्य संख्या निर्धारणको सबैभन्दा मूलभूत विधि तलका दुई चरणहरू हुन्।
- यदि संख्या ( n ) 2 भन्दा कम छ भने, त्यसलाई अभाज्य होइन भनेर निर्धारण गरिन्छ।
- ( n ) लाई 2 देखि ( sqrt{n} ) सम्मको पूर्णांकले भाग गर्दा, बाँकी 0 भएमा अभाज्य होइन भनेर निर्धारण गरिन्छ।
यो विधिलाई “ट्रायल डिभिजन मेथड” भनिन्छ, र सानो स्तरको निर्धारणमा पर्याप्त प्रदर्शन देखाउँछ।
सी भाषामा मूलभूत कार्यान्वयन उदाहरण
तलको कोड प्रयोगकर्ताले इनपुट गरेको पूर्णांक अभाज्य हो कि होइन निर्धारण गर्ने सरल कार्यक्रम हो।
#include <stdio.h>
#include <math.h>
// अभाज्य संख्या जाँच गर्ने फङ्सन
int is_prime(int n) {
if (n <= 1) return 0; // १ वा तसको भन्दा कम अभाज्य संख्या होइन
if (n == 2) return 1; // २ अभाज्य संख्या हो
if (n % 2 == 0) return 0; // सम संख्या अभाज्य संख्या होइन
// केवल विषम संख्या जाँच
for (int i = 3; i <= sqrt(n); i += 2) {
if (n % i == 0) return 0; // विभाज्य भए अभाज्य संख्या होइन
}
return 1; // अभाज्य संख्या हो
}
int main() {
int num;
// इनपुट
printf("कृपया पूर्णांक प्रविष्ट गर्नुहोस्: ");
scanf("%d", #);
// जाँच र परिणाम प्रदर्शन
if (is_prime(num))
printf("%d एक अभाज्य संख्या हो。\n", num);
else
printf("%d एक अभाज्य संख्या होइन。\n", num);
return 0;
}
कोडको व्याख्या
- हेडर फाइलको इन्क्लुड
: मानक इनपुट/आउटपुटलाई ह्यान्डल गर्ने लाइब्रेरी।
: वर्गमूल गणना गर्न
sqrt
फङ्क्शन प्रयोग गर्न आवश्यक।
- फङ्क्शन
is_prime
n <= 1
को अवस्थामा अभाज्य होइन भनेर निर्धारण गरिन्छ।- 2 लाई विशेष केसको रूपमा अभाज्य मानिन्छ।
- सम संख्या अभाज्य नहुनाले, 2 बाहेकका सम संख्याहरूलाई हटाइन्छ।
- लूपमा केवल विषम संख्याहरू जाँच गरिन्छ, जसले गणना क्रमलाई आधा घटाउँछ।
- वर्गमूलसम्मको जाँच
- अभाज्य संख्यामा भाजकहरू सममित रूपमा अस्तित्वमा हुन्छन्, त्यसैले ( n ) लाई ( sqrt{n} ) सम्म जाँच गर्नु पर्याप्त हुन्छ।
- प्रयोगकर्ता इनपुट र परिणाम प्रदर्शन
- प्रयोगकर्ताले इनपुट गरेको पूर्णांक अभाज्य हो कि होइन निर्धारण गरी, परिणामलाई स्क्रिनमा देखाइन्छ।

4. प्रभावकारी एल्गोरिद्मको परिचय
गति बृद्धिको लागि उपायहरू
मूलभूत अभाज्य संख्या जाँच एल्गोरिद्म सरल छ, तर संख्याहरू ठूलो भएमा गणनात्मक जटिलता बढ्छ, र प्रक्रिया गति सुस्त हुन सक्छ। तलका उपायहरूद्वारा दक्षता सुधार गर्न सकिन्छ।
- सम संख्या हटाउने
- 2 बाहेकका सम संख्याहरू अभाज्य हुँदैनन्, त्यसैले केवल विषम संख्याहरूलाई जाँचको लक्ष्य बनाइन्छ।
- वर्गमूलसम्मको जाँच
- विभाजकहरू वर्गमूलको सन्दर्भमा सममित रूपमा अस्तित्वमा हुन्छन्, त्यसैले गणना दायरा ( sqrt{n} ) सम्म सीमित गरिन्छ।
5. कार्यान्वयन सम्बन्धी ध्यान दिनुपर्ने बुँदाहरू
1. ठूलो संख्याहरूको ह्यान्डलिङ
समस्या
C भाषामा, पूर्णांक प्रकार (int
) को आकार वातावरण अनुसार फरक हुन्छ, धेरैजसो 32‑बिट वातावरणमा लगभग 2.1 अर्ब(2,147,483,647)को सीमा हुन्छ। त्यसैले, ठूलो संख्याहरूलाई ह्यान्डल गर्न तलका उपायहरू आवश्यक पर्छ।
उपायहरू
long long int
को प्रयोग
- अधिकतम लगभग 9 क्विंटिलियन(9,223,372,036,854,775,807)सम्म समर्थन गर्न सक्छ।
long long int num = 9223372036854775807LL;
- बाह्य पुस्तकालयको प्रयोग
- बहु‑लम्बाइ पूर्णांकलाई ह्यान्डल गर्न सक्ने GMP पुस्तकालय(GNU MP)आदि प्रयोग गरिन्छ।
#include <gmp.h>
mpz_t num;
mpz_init(num);
2. गणनात्मक जटिलता र प्रदर्शनको अनुकूलन
समस्या
प्राइम संख्या निर्धारणको गणनात्मक जटिलता ठूलो हुन्छ, विशेष गरी ठूलो डेटा वा दायरा निर्दिष्ट गरेर प्राइम संख्या सूची बनाउँदा प्रक्रिया गति घट्छ।
अनुकूलन विधिहरू
- मेमोइजेशन(क्याच)को प्रयोग
- एक पटक निर्धारण गरिएको परिणामलाई सुरक्षित गरेर, समान इनपुटमा पुनः गणना गर्नबाट बच्न।
- समांतर प्रक्रिया परिचय
- मल्टिथ्रेड वा OpenMP प्रयोग गरेर समांतर प्रक्रिया लागू गर्दा गति सुधार हुन्छ।
#pragma omp parallel for
for (int i = 0; i < n; i++) {
// समांतर प्रक्रिया
}
- एल्गोरिदम चयनको अनुकूलन
- सानो दायरा मा “ट्रायल डिभिजन” विधि, ठूलो दायरा मा “एराटोस्थेनेस सिव” प्रयोग गरिन्छ।
3. त्रुटि ह्यान्डलिङको महत्त्व
अपवाद प्रक्रिया आवश्यकता
प्रोग्राम चलाउँदा तलका त्रुटिहरू उत्पन्न हुन सक्छन्:
- अवैध इनपुट:नकारात्मक संख्या, शून्य, वा गलत स्ट्रिङ इनपुट।
- ओभरफ्लो:धेरै ठूलो संख्याको इनपुट।
उपायहरू
- इनपुटको मान्यकरण
- केवल अंकहरूलाई स्वीकार गर्ने जाँच लागू गरिन्छ।
int num;
printf("पूर्णांक प्रविष्ट गर्नुहोस्: ");
if (scanf("%d", &num) != 1) {
printf("अवैध इनपुट हो。
");
return 1;
}
- दायरा प्रतिबन्ध
- इनपुट मानमा उपयुक्त दायरा प्रतिबन्ध लगाएर, असामान्य मानहरूलाई ह्यान्डल गरिन्छ।
- मेमोरी लीक रोकथाम
- डायनामिक मेमोरी प्रयोग गर्दा, प्रोग्राम समाप्त हुनु अघि निश्चित रूपमा मुक्त गरिन्छ।
4. कोडको पठनीयता र मर्मत सम्भावना
समस्या
शुरु गर्नेहरूका लागि बनाइएको प्रोग्राम पनि, कोड जटिल भएमा पठनीयता घट्छ र मर्मत कठिन हुन्छ।
सुधार बुँदाहरू
- फङ्सनको विभाजन
- प्रत्येक कार्यको लागि फङ्सन अलग्गै लेखेर, एकल जिम्मेवारी सिद्धान्त पालना गर्नु।
- टिप्पणीहरूको समृद्धि
- प्रत्येक प्रक्रियाको उद्देश्य र ध्यान दिनुपर्ने बुँदाहरूलाई कोडमा स्पष्ट रूपमा लेख्नु।
- चलको नामको अर्थ स्पष्ट बनाउनु
num
वाprime
को सट्टा,input_number
वाis_prime_result
जस्ता विशिष्ट नामहरू प्रयोग गर्नु।

6. नमूना कोडको चलाउने उदाहरण
यस खण्डमा, अहिलेसम्म परिचय गराइएका C भाषा को अभाज्य संख्या जाँच कार्यक्रम र एराटोस्थेनेसको छान्ने (sieve) को कार्य उदाहरण देखाइन्छ। वास्तविक आउटपुट परिणामसँगै, प्रत्येक कार्यक्रमको व्यवहारलाई पुष्टि गर्नेछौं।
मूलभूत अभाज्य संख्या जाँच कार्यक्रमको चलाउने उदाहरण
कोड उदाहरण(पुनः प्रस्तुत)
#include <stdio.h>
#include <math.h>
// अभाज्य संख्या जाँच गर्ने फङ्सन
int is_prime(int n) {
if (n <= 1) return 0; // 1 भन्दा कम वा बराबर अभाज्य संख्या होइन
if (n == 2) return 1; // 2 अभाज्य संख्या हो
if (n % 2 == 0) return 0; // सम संख्या अभाज्य संख्या होइन
// केवल विषम संख्या जाँच
for (int i = 3; i <= sqrt(n); i += 2) {
if (n % i == 0) return 0; // विभाज्य भए अभाज्य संख्या होइन
}
return 1; // अभाज्य संख्या जाँच
}
int main() {
int num;
// इनपुट
printf("कृपया पूर्णांक प्रविष्ट गर्नुहोस्: ");
scanf("%d", #);
// जाँच र परिणाम प्रदर्शन
if (is_prime(num))
printf("%d अभाज्य संख्या हो。\n", num);
else
printf("%d अभाज्य संख्या होइन。\n", num);
return 0;
}
चलाउने उदाहरण
तल इनपुट र आउटपुटको उदाहरणहरू छन्।
कृपया पूर्णांक प्रविष्ट गर्नुहोस्: 17
17 यो अभाज्य संख्या हो।
कृपया पूर्णांक प्रविष्ट गर्नुहोस्: 18
18 यो अभाज्य संख्या होइन।
कृपया पूर्णांक प्रविष्ट गर्नुहोस्: 1
1 यो अभाज्य संख्या होइन।
कृपया पूर्णांक प्रविष्ट गर्नुहोस्: -5
-5 यो अभाज्य संख्या होइन।
एराटोस्थेनेसको छान्ने कार्यक्रमको चलाउने उदाहरण
कोड उदाहरण(पुनः प्रस्तुत)
#include <stdio.h>
#include <stdbool.h>
#define MAX 1000 // प्रधान संख्याहरू खोज्ने सीमा माथिको सीमा
void sieve_of_eratosthenes(int n) {
bool prime[n + 1]; // प्रधान संख्या जाँचको लागि एरे
for (int i = 0; i <= n; i++)
prime[i] = true; // आरम्भ
for (int p = 2; p * p <= n; p++) {
if (prime[p]) {
for (int i = p * p; i <= n; i += p)
prime[i] = false; // गुणकहरू हटाउनुहोस्
}
}
// परिणाम प्रदर्शन
printf("प्रधान संख्याहरूको सूची:\n");
for (int i = 2; i <= n; i++) {
if (prime[i])
printf("%d ", i);
}
printf("\n");
}
int main() {
int limit;
printf("प्रधान संख्याहरू खोज्ने सीमा प्रविष्ट गर्नुहोस्: ");
scanf("%d", &limit);
if (limit < 2) {
printf("२ वा माथिको मान प्रविष्ट गर्नुहोस्।\n");
return 1;
}
sieve_of_eratosthenes(limit);
return 0;
}
चलाउने उदाहरण
तल इनपुट र आउटपुटको उदाहरणहरू छन्।
कृपया अभाज्य संख्याहरू खोज्ने सीमा प्रविष्ट गर्नुहोस्: 50
अभाज्य संख्याहरूको सूची:
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47
चलाउँदा ध्यान दिनुपर्ने बुँदाहरू
- इनपुट मानको सीमा
- अति ठूलो संख्या इनपुट गर्दा मेमोरी अभाव र प्रक्रिया गति घट्ने समस्या उत्पन्न हुन्छ। विशेष गरी एराटोस्थेनेसको छान्ने विधि ठूलो दायरा हुँदा मेमोरी प्रयोग बढ्ने कारण, उपयुक्त सीमा निर्धारण गर्नुहोस्।
- त्रुटि ह्यान्डलिङको जाँच
- अवैध मान इनपुट गरिएमा वा अनपेक्षित त्रुटि उत्पन्न भएमा, सही त्रुटि सन्देश देखाइँदैछ कि छैन जाँच गर्नुहोस्।
- पर्यावरण निर्भर कार्य जाँच
- प्रयोग गरिने C भाषाको कम्पाइलर वा मानक पुस्तकालयको संस्करण अनुसार कार्यविधि फरक हुन सक्छ। विभिन्न वातावरणमा कार्य परीक्षण गर्नु सुरक्षित हुन्छ।
7. सारांश
यस लेखमा, C भाषा प्रयोग गरेर अभाज्य संख्या जाँचबारे, आधारभूत एल्गोरिद्मदेखि प्रभावकारी कार्यान्वयनसम्म विस्तृत रूपमा व्याख्या गरिएको छ। अहिलेसम्मको सामग्रीलाई पुनरावलोकन गर्दै, भविष्यको अध्ययन र प्रयोगका उदाहरणहरू पनि प्रस्ताव गरिएको छ।
1. लेखका मुख्य बुँदाहरूको पुनरावलोकन
- अभाज्य संख्या के हो
- अभाज्य संख्या ती प्राकृतिक संख्याहरू हुन् जसको 1 र आफैँ बाहेक कुनै अन्य भाजक हुँदैन, र गणित तथा इन्क्रिप्शन प्रविधिमा महत्वपूर्ण भूमिका खेल्दछन्।
- C भाषामा आधारभूत अभाज्य संख्या जाँच विधि
- हामीले ट्रायल डिभिजन विधि प्रयोग गरेर सरल र व्यावहारिक अभाज्य संख्या जाँच कार्यक्रम प्रस्तुत गरेका छौं। वर्गमूलसम्मको जाँचद्वारा कार्यक्षमता बढाइएको छ।
- प्रभावकारी एल्गोरिद्मको परिचय
- हामीले एराटोस्थेनेसको चलनी प्रयोग गरेर ठूलो संख्यामा अभाज्य संख्याहरूलाई द्रुत रूपमा जाँच र सूचीबद्ध गर्ने विधि व्याख्या गरेका छौं। यो एल्गोरिद्म ठूलो डेटा प्रशोधनका लागि उपयुक्त छ।
- कार्यान्वयनका ध्यान दिनुपर्ने बुँदाहरू
- ठूलो संख्याहरूको ह्यान्डलिंग, त्रुटि व्यवस्थापन, गणनात्मक जटिलताको अनुकूलन सम्बन्धी ध्यान दिनुपर्ने बुँदाहरू र सुधार उपायहरू प्रस्तुत गरेका छौं।
- नमूना कोडको कार्यान्वयन उदाहरण
- वास्तविक रूपमा चल्ने कार्यक्रम प्रस्तुत गरी, कोड र आउटपुट परिणामको जाँच मार्फत बुझाइलाई गहिरो बनायौं।
2. भविष्यका प्रयोगका उदाहरणहरू र उन्नत अध्ययन विषयहरू
यस लेखमा सिकेको अभाज्य संख्या जाँच एल्गोरिद्मलाई अझै प्रयोग र विकास गर्न सकिन्छ। तल, अर्को चरणको रूपमा अध्ययन र कार्यान्वयन गर्न सकिने विषयहरू प्रस्तुत गरिएका छन्।
1. अझ उन्नत एल्गोरिद्मको अध्ययन
- मिलर-राबिन अभाज्य जाँच विधि
- यो सम्भाव्य अभाज्य जाँच विधि हो, जसले ठूलो स्तरको अभाज्य जाँचलाई द्रुत रूपमा गर्न सक्षम बनाउँछ।
- AKS अभाज्य जाँच विधि
- यो एल्गोरिद्मले निश्चित रूपमा अभाज्य हो कि होइन जाँच गर्छ, र गणितीय रूपमा पनि महत्वपूर्ण विधि हो।
2. इन्क्रिप्शन प्रविधिमा प्रयोग
- RSA इन्क्रिप्शनको समझ र कार्यान्वयन
- अभाज्य संख्याहरू प्रयोग गरेर सार्वजनिक कुञ्जी इन्क्रिप्शनको सिद्धान्त सिकेर, वास्तविक इन्क्रिप्शन प्रणाली निर्माण गरेर प्रयोगात्मक क्षमतालाई सुदृढ बनाइन्छ।
3. ठूलो डेटा प्रशोधन र अनुकूलन
- समांतर प्रशोधन र GPU प्रयोग गरेर एल्गोरिद्मको अनुकूलन सिकेर, विशाल डेटा द्रुत रूपमा प्रशोधन गर्ने चुनौती लिन सकिन्छ।
4. C भाषा बाहेकका प्रोग्रामिङ भाषामा कार्यान्वयन
- Python, C++ जस्ता अन्य भाषाहरूमा अभाज्य जाँच एल्गोरिद्म कार्यान्वयन गरी, प्रत्येक भाषाको भिन्नताहरू तुलना गर्नु पनि उपयोगी हुन्छ।
3. अन्तमा
अभाज्य जाँच प्रोग्रामिङको आधारभूत विषय भएता पनि, इन्क्रिप्शन प्रविधि र गणितीय एल्गोरिद्मको प्रयोगजस्ता उन्नत प्रविधिहरूसँग पनि सम्बन्धित विषय हो। यस लेखमार्फत C भाषामा आधारभूत अभाज्य जाँच सिकेर, थप प्रभावकारी एल्गोरिद्म र प्रयोग क्षेत्रहरूमा चुनौती लिनको लागि प्रेरणा प्राप्त भएकोमा हामी खुशी छौं।
अगाडि पनि C भाषा अध्ययन जारी राखेर, अझ उच्च