zoukankan      html  css  js  c++  java
  • 题目八 one + two = 3 soj

    读入两个小于100的正整数A和B,计算A+B。需要注意的是:A和B的每一位数字由对应的英文单词给出。

    测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔。当A和B同时为0时输入结束,相应的结果不要输出。

    对每个测试用例输出1行,即A+B的值。

    输入:

    one + two =
    three four + five six =
    zero seven + eight nine =
    zero + zero =
    输出:
    3
    90
    96
    代码:
    字符串比较:
    //====================================================
    //名称:程序设计C 实验三 题目八 one + two = 3(0287)
    //作者:郭成涛
    //时间:2017-08-15
    //简介:读入两个小于100的正整数A和B,计算A+B。需要注意的是:A和B的每一位数字由对应的英文单词给出。
    //====================================================
    #include<stdio.h>
    #include<string.h>
    int cmp(char s[])
    {
        if(strcmp(s,"zero")==0) return 0;
        else if(strcmp(s,"one")==0) return 1;
        else if(strcmp(s,"two")==0) return 2;
        else if(strcmp(s,"three")==0) return 3;
        else if(strcmp(s,"four")==0) return 4;
        else if(strcmp(s,"five")==0) return 5;
        else if(strcmp(s,"six")==0) return 6;
        else if(strcmp(s,"seven")==0) return 7;
        else if(strcmp(s,"eight")==0) return 8;
        else if(strcmp(s,"nine")==0) return 9;
         
    }
    main()
    {
        char str[101];
        int num_a,num_b;
        while(scanf("%s",&str)!=EOF)//输入第一个字符串
        {
            num_a=cmp(str);
            scanf("%s",&str);//输入第二个字符串
            if(strcmp(str,"+")!=0)
            {
                num_a=num_a*10+cmp(str);
                scanf("%s",&str);//输入+加号
            }
            scanf("%s",&str);//输入第三个字符串
            num_b=cmp(str);
            scanf("%s",&str);//输入第四个字符串
            if(strcmp(str,"=")!=0)
            {
                num_b=num_b*10+cmp(str);
                scanf("%s",&str);//输入等号=
            }
            if(num_a==0&&num_b==0)
            {
                break;
            }
            printf("%d
    ",num_a+num_b);//求和
        }
    }

    代码2:

    //====================================================
    //名称:程序设计C 实验三 题目八 one + two = 3(0287)
    //作者:郭成涛
    //时间:2015-11-28
    //简介:读入两个小于100的正整数A和B,计算A+B。需要注意的是:A和B的每一位数字由对应的英文单词给出。
    //====================================================
    #include<stdio.h>
    #include<string.h>
    int cmp(char s[])
    {
        if(strcmp(s,"zero")==0) return 0;
        else if(strcmp(s,"one")==0) return 1;
        else if(strcmp(s,"two")==0) return 2;
        else if(strcmp(s,"three")==0) return 3;
        else if(strcmp(s,"four")==0) return 4;
        else if(strcmp(s,"five")==0) return 5;
        else if(strcmp(s,"six")==0) return 6;
        else if(strcmp(s,"seven")==0) return 7;
        else if(strcmp(s,"eight")==0) return 8;
        else if(strcmp(s,"nine")==0) return 9;
         
    }
    main()
    {
        int count=0,i=10,a=0,temp=0;
        char s[10];
        while(scanf("%s",s)!=EOF)
        {
            if(strcmp(s,"=")==0)
            {
                if(count==2)
                    a+=temp;
                else if(count==1)
                    a+=temp/10;
                if(a==0)
                    return 0;
                else
                    printf("%d
    ",a);
                a=0;
                temp=0;
                i=10;
                count=0;
            }
            else if(strcmp(s,"+")==0)
            {
                if(count==2)
                    a=temp;
                if(count==1)
                    a=temp/10;
                count=0;
                i=10;
                temp=0;
            }
            else
            {
                count++;
                temp+=i*cmp(s);
                i=i/10;
            }
        }
    以大多数人努力程度之低,根本轮不到去拼天赋~
  • 相关阅读:
    [Luogu1993] 小K的农场
    [Noip2013] 车站分级
    [Noip2003]加分二叉树
    [Luogu3797] 妖梦斩木棒
    UPC 6616 Small Mulitple
    STL容器之优先队列
    Dijkstra和Floyd算法
    最短路径问题---Dijkstra算法详解
    并查集
    洛谷 P1217
  • 原文地址:https://www.cnblogs.com/gcter/p/7364733.html
Copyright © 2011-2022 走看看