lwjppz 2018-11-19 04:17 采纳率: 54.5%
浏览 457
已采纳

这题这么输入一或两个数字来判断类型,怎么做啊?

图片说明

  • 写回答

2条回答 默认 最新

  • threenewbee 2018-11-19 05:40
    关注
    // Q713808.cpp : Defines the entry point for the console application.
    //
    
    #include "stdafx.h"
    
    #include "stdio.h"
    #include "stdlib.h"
    
    typedef struct
    {
        float t;
        float d;
        void * next;
    } LinkedList;
    
    int main()
    {
        int state = 0;
        LinkedList *head, *p;
        head = p = (LinkedList *)malloc(sizeof(LinkedList));
        p->d = 0.0f;
        p->t = 0.0f;
        float f = 0.0f;
        float base = 1.0;
        char ch = 0;
        char pch = ch;
        while (true)
        {
            ch = getchar();
            if (pch == '\n' && ch == '\n') break;
            pch = ch;
            switch (state)
            {
            case 0:
            case 2:
                if (ch >= '0' && ch <= '9')
                {
                    f *= 10;
                    f += (int)(ch - '0');
                }
                if (ch == '.')
                {
                    if (state == 0) state = 1; else state = 3;
                }
                if (ch == ' ') 
                {
                    p->d = f;
                    f = 0.0;
                    base = 1.0;
                    state = 2;
                }
                if (ch == '\n') 
                {
                    p->t = f;
                    f = 0.0;
                    base = 1.0;
                    state = 0;
                    p->next = (LinkedList *)malloc(sizeof(LinkedList));
                    p = (LinkedList *)p->next;
                    p->d = 0.0f;
                    p->t = 0.0f;
                    p->next = NULL;
                }
                break;
            case 1:
            case 3:
                if (ch >= '0' && ch <= '9')
                {
                    base /= 10.0;
                    f += base * (int)(ch - '0');
                }
                if (ch == ' ') 
                {
                    p->d = f;
                    f = 0.0;
                    base = 1.0;
                    state = 0;
                }
                if (ch == '\n') 
                {
                    p->t = f;
                    f = 0;
                    base = 1.0;
                    state = 0;
                    p->next = (LinkedList *)malloc(sizeof(LinkedList));
                    p = (LinkedList *)p->next;
                    p->d = 0.0f;
                    p->t = 0.0f;
                    p->next = NULL;
                }
                break;
            }
        }
        p = head;
        while (p->next != NULL)
        {
            if (p->d == 0.0f && int(p->t) - (p->t) <= 0.0001 && int(p->t) - (p->t) >= -0.0001)
                p->t = (float)((int)(p->t) - 1);
            if (p->d != 0.0f)
                printf("%.2f\n", 2.0 * p->d + 0.2 * p->t);
            else
                printf("%d\n", int(p->t));
            p = (LinkedList *)p->next;
        }
        return 0;
    }
    
    
    

    图片说明

    如果问题得到解决,请点我回答左上角的采纳,谢谢

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘