1600, 78/80 ȸ¿ø°¡ÀÔ  ·Î±×ÀΠ 
   ¼Ò¿ï
   http://souldesign.pe.kr
   [ÀÚÀÛ] [C¹®Á¦] ¼Ò¼ö¸¸ °É·¯³»±â

http://www.hackerschool.org/HS_Boards/zboard.php?id=Free_Lectures&no=1440 [º¹»ç]


[filtering_prime_number.c]

Q. ÀÔ·ÂÆÄÀÏ¿¡ ÀÔ·ÂµÈ ¼ýÀÚµé Áß ¼Ò¼ö(Prime Number)¸¸À» °ñ¶ó³» Ãâ·ÂÇ϶ó.

<ÀÔ/Ãâ·ÂÆÄÀÏ ¿¹>
[input.txt]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30

[output.txt]
2 3 5 7 11 13 17 19 23 29


A. ¿¹Á¦¼Ò½º

#include <stdio.h>
#include <string.h>
#include <math.h> //sqrt(Á¦°ö±Ù, ·çÆ®)¸¦ »ç¿ëÇϱâ À§ÇØ math.h ÀÎŬ·çµå

const int MAX_SIZE = 255; //»ó¼ö¸¦ const·Î Á¤ÀÇ

int isPrimeNum(int num); //ÇÔ¼öÀÇ ¿øÇü ¼±¾û

int main(void) {
        FILE * input = fopen("input.txt", "r"); //ÀÔ·Â ÆÄÀÏ
        FILE * output = fopen("output.txt", "w"); //Ãâ·Â ÆÄÀÏ

        char txt[MAX_SIZE]; //input.txtÀÇ ³»¿ëÀ» ÀúÀåÇÒ ¹®ÀÚ¿­
        char tmp[10] = ""; //·çÇÁ¸¦ µ¹¶§¸¶´Ù »ý±â´Â ¼ýÀÚ¸¦ ÀúÀå
        char nums[MAX_SIZE]; //¼Ò¼öµéÀ» ÀúÀåÇÒ ¹®ÀÚ¿­, Ãâ·Â¿¡ »ç¿ë

        fgets(txt, sizeof(txt), input); //input.txt >> txt
        
        int i;
        for(i=0; i<=strlen(txt); i++) {
                if(txt[i] != ' ' && txt[i] != '\0') { //txtÀÇ i¹ø° ¹®ÀÚ°¡ °ø¹é(' ')ÀÌ ¾Æ´Ï°í ³Î¹®ÀÚ°¡ ¾Æ´Ò ¶§
                        tmp[strlen(tmp)] = txt[i]; //tmp¿¡ txtÀÇ i¹ø° ¹®ÀÚ¸¦ Ãß°¡
                } else {
                        if(isPrimeNum(atoi(tmp)) == 1) { //tmp¿¡ ÀúÀåµÈ ³»¿ëÀ» ¼ýÀÚ·Î ¹Ù²Û °Í(atoi)ÀÌ ¼Ò¼öÀÏ ¶§
                                //¼ýÀÚ¸¦ ±¸ºÐÇϱâ À§ÇÑ °ø¹é Ãß°¡
                                if(strlen(nums) != 0)
                                        strcat(nums, " ");

                                strcat(nums, tmp); //nums ¹®ÀÚ¿­¿¡ tmp Ãß°¡
                        }
                        memset(tmp, 0, sizeof(tmp)); //tmpÀÇ ³»¿ëÀ» ÃʱâÈ­
                        
                }
        }

        fprintf(output, nums);
        
        fclose(input);
        fclose(output);

        return 0;
}

//ÀÎÀÚ·Î ¹ÞÀº numÀÌ ¼Ò¼öÀÏ ¶§ 1À» ¸®ÅÏÇÔ
int isPrimeNum(int num) {
        if(num == 1 || num == 0) //numÀÌ 0 ¶Ç´Â 1ÀÏ ¶§ ÇÕ¼º¼ö
                return 0;

        //¡înum¸¸Å­ i¸¦ µ¹·Á¼­ ³ª´©¾î¶³¾îÁö´Â ¼ö°¡ ÀÖÀ¸¸é ÇÕ¼º¼ö
        int i;
        for(i=2; i<=sqrt(num); i++) {
                if(num%i == 0)
                        return 0;
        }

        return 1;
}

  Hit : 8649     Date : 2010/03/20 05:28



    
Myers ±»~ 2010/03/21  
Cpgroot ÁÁÀºÁ¤º¸ °¨»çÇÕ´Ï´Ù. 2010/08/18  
60   ¸®´ª½º ¸í·É¾î ¸¶½ºÅÍ 5[8]     ¼ÒÀ¯
09/06 16178
59   ·¹À̽º ÄÁµð¼Ç(°æÀï Á¶°Ç)[14]     ¼ÒÀ¯
09/06 15588
58   [[ÃʱÞ/°­ÁÂ]] À¯´Ð½º ÁÖ¿ä ¸í·É¾î[7]     ¼ÒÀ¯
10/09 15432
57   [[ÃʱÞ/°­ÁÂ]] À¯´Ð½º ±âº» Á¤¸®[8]     ¼ÒÀ¯
10/09 15191
56   Äְܼú ¿¢½ºÀ©µµ¿¡¼­ ¸¶¿ì½º »ç¿ëÇϱâ[1]     ¼ÒÀ¯
10/28 10632
55   ¸®´ª½º ¸í·É¾î ¸¶½ºÅÍ 6[7]     ¼ÒÀ¯
09/08 15029
54   ¸®´ª½º ¸í·É¾î ¸¶½ºÅÍ 7[8]     ¼ÒÀ¯
09/09 14900
53   [Ưº°] find ¸í·É¾î[7]     ¼ÒÀ¯
09/09 16634
52   ¸®´ª½º ¸í·É¾î ¸¶½ºÅÍ 8 [¸¶Áö¸·][44]     ¼ÒÀ¯
09/10 15472
51   ³×Æ®¿öÅ© °³³ä ÈÖ¾îÀâ±â 1[24]     ¼ÒÀ¯
09/10 19995
50   ³×Æ®¿öÅ© °³³ä ÈÖ¾îÀâ±â 2[16]     ¼ÒÀ¯
09/11 15747
49   ¼ÒÄÏ ÇÁ·Î±×·¡¹Ö[5]     ¼ÒÀ¯
09/11 17577
48   ³× Æ® ¿ö Å© °­ ÁÂ[17]     ¼ÒÀ¯
10/05 18850
47   ³×Æ®¿öÅ© °³³ä ÈÖ¾îÀâ±â 3[17]     ¼ÒÀ¯
09/12 13858
46   ³×Æ®¿öÅ© °³³ä ÈÖ¾îÀâ±â 6[10]     ¼ÒÀ¯
09/15 12720
45   ³×Æ®¿öÅ© °³³ä ÈÖ¾îÀâ±â 4[14]     ¼ÒÀ¯
09/13 14009
44   ¸®´ª½ºÀÇ °ÅÀÇ ¸ðµç ¸í·É¾î?[314]     ¼ÒÀ¯
10/05 33737
43   ³×Æ®¿öÅ© °³³ä ÈÖ¾îÀâ±â 5[10]     ¼ÒÀ¯
09/14 13573
42   ÇØÅ·´çÇÑ ¼­¹ö¿¡¼­ È®ÀÎÇؾßÇÒÀÏ[9]     ¼ÒÀ¯
09/21 21893
41   ¸®´ª½º ¼³Ä¡Çϱâ - ±âÃÊÆí[5]     ¼ÒÀ¯
10/06 12015
[1]..[71][72][73][74][75][76][77] 78 [79][80]

Copyright 1999-2025 Zeroboard / skin by Hackerschool.org / Secure Patch by Hackerschool.org