码迷,mamicode.com
首页 > 其他好文 > 详细

1024. 科学计数法(两点未通过)

时间:2018-02-28 16:30:16      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:lib   char   字符   pos   截图   img   scanf   image   bsp   

 题目截图:

技术分享图片

 

思路:

  字符串处理。根据指数正负做不同处理。

 

代码:

/*
    1024. 科学计数法
*/

#include <stdio.h>
#include <string.h>
#include <math.h>
#include <stdlib.h>
#include <time.h>

#define maxn 10010
char str[maxn];                    // 存储输入值 

int main() {
    // a为整数部分
    // b为E位置,c为指数 
    int i, a, b, c=0, flag=1;     
    scanf("%s", str);
    a = str[1]-0;
    // 查找 E 所在位置 
    for(i=3; i<strlen(str); ++i) {
        if(str[i]==E) {
            b = i;
            break;
        }
    }
    i++;
    // 求指数 
    if(str[i]==+) {
        flag=1;
    }  else {
        flag = -1;
    }
    i++;
    for(; i<strlen(str); ++i) {
        c = c*10+(str[i]-0);
    }
    c = flag*c;
    if(str[0]==-) {
        printf("-"); 
    }
    if(c > 0) {                    // 若指数为正 
        printf("%d", a);
        int l = b-2;
        if(c>l) {                // 去掉小数点,在后面加 0 
            for(i=3; i<b; ++i) {
                printf("%c", str[i]);
            }
            for(i=0;i<c-l+1; ++i) {
                printf("0");
            }
        } else {                // 小数点向右移 c 位 
            for(i=0; i<c; ++i) {
                printf("%c", str[3+i]);
            }
            printf(".");
            i+=3;
            for(; i<b; ++i) {
                printf("%c", str[i]);
            } 
        }
    } else if(c < 0) {            // 若指数为负 
        int l = -c-1;
        printf("0.");            // 前面加 0. 
        for(i=0; i<l; ++i) {    // 小数点向左移 c 位 
            printf("0");
        }
        printf("%d", a);
        for(i=3; i<b; ++i) {
            printf("%c", str[i]);
        }
    } else {                    // 若指数为 0 
        for(i=1; i<b; ++i) {
            printf("%c", str[i]);
        }
    }

    return 0;
}

 

 

:此代码有两个点没过,至今没找到原因。

 

1024. 科学计数法(两点未通过)

标签:lib   char   字符   pos   截图   img   scanf   image   bsp   

原文地址:https://www.cnblogs.com/coderJiebao/p/PAT1024.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!