草庐IT

关于 c :使用 if else 将数字转换为单词

codeneng 2023-03-28 原文

Converting number into words using if else

我是 c 的初学者。我编写了一个程序来将数字转换为单词。对于 11-19 之间的数字和像这样的数字 20、30、40、50、60、70、80、90,我得到了错误的输出。我还尝试在最后两个 if 语句之间添加 else 语句,这样即使第一个 if 为真,它也不会执行所有 if 语句,但它给了我一个错误,即 "else without a previous if"。

//This program converts number into words
#include<iostream>
using namespace std;
main()
{
    int number,unit,ten;
    cout<<"Please enter any number between 0-99:";
    cin>>number;
    ten=number/10;
    unit=number%10;
    if(number<0 | number>99)
        cout<<"Number is out of range";
    if(number>=11 && number <=19);
    {
        if(number==11) cout<<"eleven";
        if(number==12) cout<<"twelve";
        if(number==13) cout<<"thirteen";
        if(number==14) cout<<"fourteen";
        if(number==15) cout<<"fifteen";
        if(number==16) cout<<"sixteen";
        if(number==17) cout<<"seventeen";
        if(number==18) cout<<"eighteen";
        if(number==19) cout<<"ninteen";
    }
    if(ten>=2 && ten<=9)    
    {  
        if(ten==1) cout<<"ten";
        if(ten==2) cout<<"twenty";
        if(ten==3) cout<<"thirty";
        if(ten==4) cout<<"fourty";
        if(ten==5) cout<<"fifty";
        if(ten==6) cout<<"sixty";
        if(ten==7) cout<<"seventy";
        if(ten==8) cout<<"eighty";
        if(ten==9) cout<<"ninty";
    }
    if(unit>=0 && unit <=9)
    {
        if(unit==0) cout<<" zero";
        if(unit==1) cout<<" one";
        if(unit==2) cout<<" two";
        if(unit==3) cout<<" three";
        if(unit==4) cout<<" four";
        if(unit==5) cout<<" five";
        if(unit==6) cout<<" six";
        if(unit==7) cout<<" seven";
        if(unit==8) cout<<" eight";
        if(unit==9) cout<<" nine";
    }
}

输出1:-

Please enter any number between 0-99: 12
twelve two

输出2:-

Please enter any number between 0-99: 30
thirty zero

  • 打开编译器警告。
  • 您的代码中还有另一个错误,但您很幸运它没有咬您。当您打算使用逻辑 OR || 时,您使用的是按位 OR |if (number < 0 || number > 99) 它似乎仍然有效的原因是一些历史原因的巧合。
  • 代码风格:在 if 和它的开头 ( 之间总是有一个空格。操作数之间还有一个空格:unit == 7 而不是 unit==7。我知道这听起来无关紧要,但这是你的手艺,就这样对待吧。


在第二个 if 之后有一个分号 ;。此外,您应该使用 || 而不是 |。你也应该排除 ten==1.

时的情况

//This program converts number into words
#include<iostream>
using namespace std;
main()
{
    int number,unit,ten;
    cout<<"Please enter any number between 0-99:";
    cin>>number;
    ten=number/10;
    unit=number%10;
    if(number<0 || number>99)
    {
        cout<<"Number is out of range";
    }
    if(ten == 1)
    {
        if(number==10) cout<<"ten";
        if(number==11) cout<<"eleven";
        if(number==12) cout<<"twelve";
        if(number==13) cout<<"thirteen";
        if(number==14) cout<<"fourteen";
        if(number==15) cout<<"fifteen";
        if(number==16) cout<<"sixteen";
        if(number==17) cout<<"seventeen";
        if(number==18) cout<<"eighteen";
        if(number==19) cout<<"ninteen";
    }
    else {  
        if(ten==2) cout<<"twenty";
        if(ten==3) cout<<"thirty";
        if(ten==4) cout<<"fourty";
        if(ten==5) cout<<"fifty";
        if(ten==6) cout<<"sixty";
        if(ten==7) cout<<"seventy";
        if(ten==8) cout<<"eighty";
        if(ten==9) cout<<"ninty";

        // ****
        if(unit==0 && ten ==0) cout<<" zero";
        if(unit==1) cout<<" one";
        if(unit==2) cout<<" two";
        if(unit==3) cout<<" three";
        if(unit==4) cout<<" four";
        if(unit==5) cout<<" five";
        if(unit==6) cout<<" six";
        if(unit==7) cout<<" seven";
        if(unit==8) cout<<" eight";
        if(unit==9) cout<<" nine";
    }
}

所有情况的输出:

Please enter any number between 0-99: -1
Number is out of range

Please enter any number between 0-99: 0
 zero

Please enter any number between 0-99: 1
 one

Please enter any number between 0-99: 2
 two

Please enter any number between 0-99: 3
 three

Please enter any number between 0-99: 4
 four

Please enter any number between 0-99: 5
 five

Please enter any number between 0-99: 6
 six

Please enter any number between 0-99: 7
 seven

Please enter any number between 0-99: 8
 eight

Please enter any number between 0-99: 9
 nine

Please enter any number between 0-99: 10
ten

Please enter any number between 0-99: 11
eleven

Please enter any number between 0-99: 12
twelve

Please enter any number between 0-99: 13
thirteen

Please enter any number between 0-99: 14
fourteen

Please enter any number between 0-99: 15
fifteen

Please enter any number between 0-99: 16
sixteen

Please enter any number between 0-99: 17
seventeen

Please enter any number between 0-99: 18
eighteen

Please enter any number between 0-99: 19
ninteen

Please enter any number between 0-99: 20
twenty

Please enter any number between 0-99: 21
twenty one

Please enter any number between 0-99: 22
twenty two

Please enter any number between 0-99: 23
twenty three

Please enter any number between 0-99: 24
twenty four

Please enter any number between 0-99: 25
twenty five

Please enter any number between 0-99: 26
twenty six

Please enter any number between 0-99: 27
twenty seven

Please enter any number between 0-99: 28
twenty eight

Please enter any number between 0-99: 29
twenty nine

Please enter any number between 0-99: 30
thirty

Please enter any number between 0-99: 31
thirty one

Please enter any number between 0-99: 32
thirty two

Please enter any number between 0-99: 33
thirty three

Please enter any number between 0-99: 34
thirty four

Please enter any number between 0-99: 35
thirty five

Please enter any number between 0-99: 36
thirty six

Please enter any number between 0-99: 37
thirty seven

Please enter any number between 0-99: 38
thirty eight

Please enter any number between 0-99: 39
thirty nine

Please enter any number between 0-99: 40
fourty

Please enter any number between 0-99: 41
fourty one

Please enter any number between 0-99: 42
fourty two

Please enter any number between 0-99: 43
fourty three

Please enter any number between 0-99: 44
fourty four

Please enter any number between 0-99: 45
fourty five

Please enter any number between 0-99: 46
fourty six

Please enter any number between 0-99: 47
fourty seven

Please enter any number between 0-99: 48
fourty eight

Please enter any number between 0-99: 49
fourty nine

Please enter any number between 0-99: 50
fifty

Please enter any number between 0-99: 51
fifty one

Please enter any number between 0-99: 52
fifty two

Please enter any number between 0-99: 53
fifty three

Please enter any number between 0-99: 54
fifty four

Please enter any number between 0-99: 55
fifty five

Please enter any number between 0-99: 56
fifty six

Please enter any number between 0-99: 57
fifty seven

Please enter any number between 0-99: 58
fifty eight

Please enter any number between 0-99: 59
fifty nine

Please enter any number between 0-99: 60
sixty

Please enter any number between 0-99: 61
sixty one

Please enter any number between 0-99: 62
sixty two

Please enter any number between 0-99: 63
sixty three

Please enter any number between 0-99: 64
sixty four

Please enter any number between 0-99: 65
sixty five

Please enter any number between 0-99: 66
sixty six

Please enter any number between 0-99: 67
sixty seven

Please enter any number between 0-99: 68
sixty eight

Please enter any number between 0-99: 69
sixty nine

Please enter any number between 0-99: 70
seventy

Please enter any number between 0-99: 71
seventy one

Please enter any number between 0-99: 72
seventy two

Please enter any number between 0-99: 73
seventy three

Please enter any number between 0-99: 74
seventy four

Please enter any number between 0-99: 75
seventy five

Please enter any number between 0-99: 76
seventy six

Please enter any number between 0-99: 77
seventy seven

Please enter any number between 0-99: 78
seventy eight

Please enter any number between 0-99: 79
seventy nine

Please enter any number between 0-99: 80
eighty

Please enter any number between 0-99: 81
eighty one

Please enter any number between 0-99: 82
eighty two

Please enter any number between 0-99: 83
eighty three

Please enter any number between 0-99: 84
eighty four

Please enter any number between 0-99: 85
eighty five

Please enter any number between 0-99: 86
eighty six

Please enter any number between 0-99: 87
eighty seven

Please enter any number between 0-99: 88
eighty eight

Please enter any number between 0-99: 89
eighty nine

Please enter any number between 0-99: 90
ninty

Please enter any number between 0-99: 91
ninty one

Please enter any number between 0-99: 92
ninty two

Please enter any number between 0-99: 93
ninty three

Please enter any number between 0-99: 94
ninty four

Please enter any number between 0-99: 95
ninty five

Please enter any number between 0-99: 96
ninty six

Please enter any number between 0-99: 97
ninty seven

Please enter any number between 0-99: 98
ninty eight

Please enter any number between 0-99: 99
ninty nine

Please enter any number between 0-99: 100
Number is out of range

  • 接得好!具有讽刺意味的是,第二个 if 完全没有必要,因为它的主体中的 if 语句处理了它的工作。
  • 现在它适用于 11 到 19 之间的数字,但它仍然为数字 10、20、30 等提供错误的输出。 30 的输出是"三十零"。
  • @MoazAli,感谢您指出。我稍微改变了程序逻辑,现在它适用于所有情况。


  • 您应该使用 int main() 而不是 main() 并在 int main() 中添加 return 0;
  • if(number<0 | number>99) 行应该是 if(number<0 || number>99)
  • if(number>=11 && number <=19); 行应该是 if(number>=11 && number <=19)
  • if(ten>=2 && ten<=9) 之前应添加 else
  • 以下 code 可以工作:

    //This program converts number into words
    #include<iostream>
    using namespace std;
    int main()
    {
        int number,unit,ten;
        cout<<"Please enter any number between 0-99:";
        cin>>number;
        ten=number/10;
        unit=number%10;
        if(number<0 || number>99)
            cout<<"Number is out of range";
        if(number>=11 && number <=19)
        {
            if(number==11) cout<<"eleven";
            if(number==12) cout<<"twelve";
            if(number==13) cout<<"thirteen";
            if(number==14) cout<<"fourteen";
            if(number==15) cout<<"fifteen";
            if(number==16) cout<<"sixteen";
            if(number==17) cout<<"seventeen";
            if(number==18) cout<<"eighteen";
            if(number==19) cout<<"ninteen";
        } else {
            if(ten>=2 && ten<=9)
            {
                if(ten==1) cout<<"ten";
                if(ten==2) cout<<"twenty";
                if(ten==3) cout<<"thirty";
                if(ten==4) cout<<"fourty";
                if(ten==5) cout<<"fifty";
                if(ten==6) cout<<"sixty";
                if(ten==7) cout<<"seventy";
                if(ten==8) cout<<"eighty";
                if(ten==9) cout<<"ninty";
            }
            if(unit>=0 && unit <=9)
            {
                if(unit==0) cout<<" zero";
                if(unit==1) cout<<" one";
                if(unit==2) cout<<" two";
                if(unit==3) cout<<" three";
                if(unit==4) cout<<" four";
                if(unit==5) cout<<" five";
                if(unit==6) cout<<" six";
                if(unit==7) cout<<" seven";
                if(unit==8) cout<<" eight";
                if(unit==9) cout<<" nine";
            }
        }

        return 0;
    }

    • 我不同意"在 int main() 中添加 return 0;"。当然可以这样做,但是在简洁很重要的stackoverflow问题中,最好让编译器为您添加它;)仍然赞成


    对于这种情况,switch 语句更有意义。试试这个代码:

    #include<iostream>
    using namespace std;
    int main()
    {
        for (int number = 1; number <= 99; number++)
        {
            int ten=number/10;
            int unit=number%10;
            if(number<0 || number>99)
            {
                cout<<"Number is out of range";
                return 1;
            }
            if(ten == 1)
            {
                switch ( number )
                {
                case 10: cout<<"ten"; break;
                case 11: cout<<"eleven"; break;
                case 12: cout<<"twelve"; break;
                case 13: cout<<"thirteen"; break;
                case 14: cout<<"fourteen"; break;
                case 15: cout<<"fifteen"; break;
                case 16: cout<<"sixteen"; break;
                case 17: cout<<"seventeen"; break;
                case 18: cout<<"eighteen"; break;
                case 19: cout<<"nineteen"; break;
                }
            }
            else
            {
                if(ten>=2 && ten<=9)    
                {  
                    switch (ten)
                    {
                    case 2: cout<<"twenty"; break;
                    case 3: cout<<"thirty"; break;
                    case 4: cout<<"fourty"; break;
                    case 5: cout<<"fifty"; break;
                    case 6: cout<<"sixty"; break;
                    case 7: cout<<"seventy"; break;
                    case 8: cout<<"eighty"; break;
                    case 9: cout<<"ninty"; break;
                    }
                }
                if ( unit != 0 and ten != 0 )
                {
                    cout <<"";
                }
                switch ( unit )
                {
                    case 0: if ( ten == 0 ) cout<<"zero"; break;
                    case 1: cout<<"one"; break;
                    case 2: cout<<"two"; break;
                    case 3: cout<<"three"; break;
                    case 4: cout<<"four"; break;
                    case 5: cout<<"five"; break;
                    case 6: cout<<"six"; break;
                    case 7: cout<<"seven"; break;
                    case 8: cout<<"eight"; break;
                    case 9: cout<<"nine"; break;
                }
            }
            cout <<"\
    "
    ;
        }
        return 0;
    }

    我还发现了以下错误:

  • 您在第一个 if 语句中使用按位或 | 而不是布尔值或 ||。您也不会在打印 "Number is out of range" 后停止其余代码,我已通过返回解决了这个问题。
  • 第二个 if 语句的末尾有一个分号,这个 if 语句也可以简化为 ten == 1
  • 您需要防止在打印 \\'teens 后运行其余代码,这可以通过 else 来完成。
  • 您永远不会打印 "ten",它可能应该与 \\'teens 一起打印,但会打印 20、30 等,但由于周围的 if 语句,它实际上永远不会被打印。
  • 您在 20、30 等之后打印"零"。如果 ten0,则仅打印 "zero" 可以解决此问题。
  • if 语句 if(unit>=0 && unit <=9) 将始终为真,因此可以删除。

  • 由于您的if条件,您得到的实际上是正确的。如果您写下 3 个 if 条件,它将检查其中的三个。另外,去掉第二个 if!

    的分号

    所以第一个 12 转到第一个 if 并打印 "twelve"。

    转到第二个 if12/101.2,所以作为一个 int,它是 `1。它不会进入第二个 if。由于分号,它无论如何都不会进入。

    但它进入第三个:12%10

    你的ifs就是这样!

    另外,我担心这对你有用:if(number<0 | number>99),因为它应该是 ||,而不是 |

    有关关于 c :使用 if else 将数字转换为单词的更多相关文章

    1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

      我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

    2. ruby - 使用 RubyZip 生成 ZIP 文件时设置压缩级别 - 2

      我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看ruby​​zip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d

    3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

      类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

    4. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

      很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

    5. ruby - 在 Ruby 中使用匿名模块 - 2

      假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于

    6. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

      我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

    7. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

      我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

    8. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

      关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

    9. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

      我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

    10. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

      我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

    随机推荐