1581, 1/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 : 8044     Date : 2010/03/20 05:28



    
Myers ±»~ 2010/03/21  
Cpgroot ÁÁÀºÁ¤º¸ °¨»çÇÕ´Ï´Ù. 2010/08/18  
     [°øÁö] °­Á¸¦ ¿Ã¸®½Ç ¶§´Â ¸»¸Ó¸®¸¦ ´Þ¾ÆÁÖ¼¼¿ä^¤Ñ^ [29] ¸Û¸Û 02/27 18775
1580   °í¼ö´ÔµéÀÇ µµ¿òÀ» ¹Þ°í ½Í½À´Ï´Ù     vbnm111
02/11 229
1579   ¸®´ª½º Ä¿³Î 2.6 ¹öÀü ÀÌÈÄÀÇ LKM     jdo
07/25 729
1578   ½©ÄÚµå ¸ðÀ½     ÇØÅ·ÀßÇÏ°í½Í´Ù
01/15 1559
1577   Call by value VS Call by Reference     ÇØÅ·ÀßÇÏ°í½Í´Ù
01/15 937
1576   (²Ä¼ö) L.O.B Çѹ濡 Ŭ¸®¾îÇϱâ[2]     ÇØÅ·ÀßÇÏ°í½Í´Ù
01/14 1280
1575   towelroot.c (zip) ÄÚ¸àÆÃ.[1]     scube
08/18 3805
1574   levitator.c (¾Èµå·ÎÀÌµå ·çÆÃ) °ø°Ý ºÐ¼® ¼Ò½º ÄÚµå °øÀ¯.[4]     scube
08/17 3709
1573   ¹«·á Á¤º¸º¸¾È ±â¼úÀÎÀç ¾ç¼º °úÁ¤ ±³À°»ý ¸ðÁý     chanjung111
06/17 4515
1572   K-Shield ÁִϾî 5±â ¸ðÁý     lrtk
06/17 4241
1571   [ÆÁ] ÆÄÀ̽ã 2¼Ò½º¸¦ 3À¸·Î º¯°æÇØÁÖ´Â »çÀÌÆ®[3]     ÇѽÂÀç
05/13 3948
1570   ±¸±Û ¹é¸µÅ© ÀÛ¾÷ Áú¹®¿ä     wkatnxka
03/30 3376
1569   [ÆÁ] ¿ìºÐÅõ ¹Ì·¯¸µ¼­¹ö     ÇѽÂÀç
03/09 4072
1568 ºñ¹Ð±ÛÀÔ´Ï´Ù  °¨À»¸øÀâ°Ú³×¿ä¤Ì¤Ì     À×À×À×
01/15 3
1567   µ¥ºñ¾È °è¿­ ¸®´ª½º ÀÇÁ¸¼º ±úÁ³À»¶§ ÇØ°á¹ý     ÇѽÂÀç
11/27 4556
1566   È«º¸ÇÕ´Ï´Ù. ½Å»ý º¸¾ÈÄ¿¹Â´ÏƼÀÔ´Ï´Ù.     kimwoojin0952
10/26 4281
1565   ½Å±âÇÑ ÇÁ·Î±×·¡¹Ö ¾ð¾î[3]     koreal33t
09/06 4680
1564   À©µµ¿ì,¸®´ª½º¿¡¼­ ³» ip¸¦ È®ÀÎÇØ º¸ÀÚ [1]     koreal33t
09/06 3878
1563   CTF »çÀÌÆ®[1]     koreal33t
09/06 4540
1562   ÀÚ°ÝÁõ (¹®Á¦)»çÀÌÆ® [2]     koreal33t
09/06 4357
1 [2][3][4][5][6][7][8][9][10]..[80]

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