1588, 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 : 8384     Date : 2010/03/20 05:28



    
Myers ±»~ 2010/03/21  
Cpgroot ÁÁÀºÁ¤º¸ °¨»çÇÕ´Ï´Ù. 2010/08/18  
     [°øÁö] °­Á¸¦ ¿Ã¸®½Ç ¶§´Â ¸»¸Ó¸®¸¦ ´Þ¾ÆÁÖ¼¼¿ä^¤Ñ^ [29] ¸Û¸Û 02/27 19173
1587   netdiscover ÆÄÀ̽ãÀ¸·Î ±¸ÇöÇϱ⠠   ÇØÅ·ÀßÇÏ°í½Í´Ù
08/13 93
1586   ÆÄÀ̽ãÀ» ÀÌ¿ëÇÑ ½ÉÇà À¥ Å©·Ñ·¯     ÇØÅ·ÀßÇÏ°í½Í´Ù
08/13 69
1585   ÆÄÀ̽ã random¸ðµâÀ» ÀÌ¿ëÇÑ ¼ýÀÚ¸ÂÃ߱⠰ÔÀÓ ±¸Çö     ÇØÅ·ÀßÇÏ°í½Í´Ù
05/30 554
1584   ÆÄÀ̽ã äÆà ÇÁ·Î±×·¥ ±¸Çö     ÇØÅ·ÀßÇÏ°í½Í´Ù
05/28 458
1583   ÆÄÀ̽㠼ÒÄÏ ÇÁ·Î±×·¡¹ÖÀÇ ±âÃÊ     ÇØÅ·ÀßÇÏ°í½Í´Ù
05/26 472
1582   ¸®´ª½º À¥ ·Î±× ºÐ¼®     ÇØÅ·ÀßÇÏ°í½Í´Ù
05/20 373
1581   ¸®´ª½º/À©µµ¿ì º¸¾È Àåºñ ·Î±×     ÇØÅ·ÀßÇÏ°í½Í´Ù
05/20 447
1580   °í¼ö´ÔµéÀÇ µµ¿òÀ» ¹Þ°í ½Í½À´Ï´Ù     vbnm111
02/11 624
1579   ¸®´ª½º Ä¿³Î 2.6 ¹öÀü ÀÌÈÄÀÇ LKM     jdo
07/25 1152
1578   ½©ÄÚµå ¸ðÀ½     ÇØÅ·ÀßÇÏ°í½Í´Ù
01/15 1987
1577   Call by value VS Call by Reference     ÇØÅ·ÀßÇÏ°í½Í´Ù
01/15 1334
1576   (²Ä¼ö) L.O.B Çѹ濡 Ŭ¸®¾îÇϱâ[2]     ÇØÅ·ÀßÇÏ°í½Í´Ù
01/14 1731
1575   towelroot.c (zip) ÄÚ¸àÆÃ.[1]     scube
08/18 4250
1574   levitator.c (¾Èµå·ÎÀÌµå ·çÆÃ) °ø°Ý ºÐ¼® ¼Ò½º ÄÚµå °øÀ¯.[4]     scube
08/17 4115
1573   ¹«·á Á¤º¸º¸¾È ±â¼úÀÎÀç ¾ç¼º °úÁ¤ ±³À°»ý ¸ðÁý     chanjung111
06/17 4968
1572   K-Shield ÁִϾî 5±â ¸ðÁý     lrtk
06/17 4662
1571   [ÆÁ] ÆÄÀ̽ã 2¼Ò½º¸¦ 3À¸·Î º¯°æÇØÁÖ´Â »çÀÌÆ®[3]     ÇѽÂÀç
05/13 4361
1570   ±¸±Û ¹é¸µÅ© ÀÛ¾÷ Áú¹®¿ä     wkatnxka
03/30 3777
1569   [ÆÁ] ¿ìºÐÅõ ¹Ì·¯¸µ¼­¹ö     ÇѽÂÀç
03/09 4489
1 [2][3][4][5][6][7][8][9][10]..[80]

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