PAT 을 급 | C 언어 | 1024 과학 계수 법 (20 점)

제목.
과학 계수 법 은 과학자 들 이 매우 크 거나 작은 숫자 를 나타 내 는 편리 한 방법 으로 정규 표현 식 [±] [1 - 9] 를 만족 시 키 는 것 이다.
현재 과학 계수 법의 형식 으로 실수 A 를 드 립 니 다. 프로그램 을 작성 하여 일반 숫자 표시 법 에 따라 A 를 출력 하고 모든 유효 위 치 를 유지 하도록 하 십시오.
입력 형식: 각 입력 은 과학 계수 법 으로 표 시 된 실수 A 를 포함 합 니 다.이 숫자의 저장 길 이 는 9999 바이트 를 초과 하지 않 고 지수의 절대 치 는 9999 를 초과 하지 않 는 다.
출력 형식: 모든 테스트 용례 에 대해 한 줄 에 일반 숫자 표시 법 에 따라 A 를 출력 하고 모든 유효 비트 가 보 존 됩 니 다. 끝의 0 을 포함 합 니 다.
입력 샘플 1:
+1.23400E-03

출력 예시 1:
0.00123400

입력 샘플 2:
-1.2E+10

출력 예시 2:
-12000000000

AC 코드
  • 유효 위 치 를 유지 하도록 요구한다.무효 한 0 은 빼 지 않 아 도 통과 할 수 있다. 다음 과 같다.
  • 입력
    0.001E2
    

    출력
    0001
    
  • 아래 코드 는 잘못된 위 치 를 제거 하지 않 고 몇 개의 문자열 로 함 수 를 처리 하 였 으 며 스스로 문 구 를 써 서 실현 할 수 있 습 니 다
  • #include
    #include
    int main(){
        char number[20000],*p_int,*p_flo,*p_pow;
        
        gets(number);
        p_int=strtok(number,".");     //       
        p_flo=strtok(NULL,"E"); 	  //       
        p_pow=strtok(NULL,"E");       //       
        int interger,pow;
        interger=atoi(p_int);        //  int     
        pow=atoi(p_pow);			 //  int     
        if(pow>=0){	//    0
            printf("%d",interger);   //      
            int i;
            for(i=0;*p_flo;i++,p_flo++){	//      
                if(i==pow)printf(".");	//        
    			printf("%c",*p_flo);
            }
            while(i<pow){	//  
            	printf("0");
            	i++;
    		}
        }
        else{	//     
    		if(interger<0){  //       
    			printf("-");	//    
    			interger=-interger;
    		}		   
            pow=-pow;  
            for(int i=0;i<pow;i++){	//     ,  
                printf("0");
                if(i==0)printf(".");
            }
            printf("%d%s",interger,p_flo);
        }
        return 0;
    }
    

    좋은 웹페이지 즐겨찾기