首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何改进我的C++代码?

如何改进我的C++代码?
EN

Stack Overflow用户
提问于 2011-01-05 12:24:58
回答 8查看 465关注 0票数 1

这是我真正创建的除hello world之外的第一个程序。这段代码有400多行代码,我想了解一些新的函数以及其他一些可以帮助我改进代码和C++知识的东西。我想我应该一头扎进去自学,而不是从我的书"Teach yourself C++ in one hour a day on 6 edition“中学到。

我可以学习哪些新函数来改进我的代码?

代码语言:javascript
运行
复制
// Runescape Mining Calculator

#include <iostream>
#include <cmath>
using namespace std;

int main()
{
    int lvl;
    int exp;
    int result;

    cout << " \t\t\tRunescape Skill Calculator" << endl;
    cout << " Enter Target level: ";
    cin>>lvl;

    switch(lvl)
    {
                    case 2: cout << " What is your current experience? ";;
                    cin >> exp;
                    result=83 - exp;
                    break;
                    case 3: cout << " What is your current experience? ";
                    cin >> exp;
                    result=174 - exp;
                    break;
                    case 4: cout << " What is your current experience? ";
                    cin >> exp;
                    result=276 - exp;
                    break;
                    case 5: cout << " What is your current experience? ";
                    cin >> exp;
                    result=388 - exp;
                    break;
                    case 6: cout << " What is your current experience? ";
                    cin >> exp;
                    result=512 - exp;
                        break;                  
                    case 7: cout << " What is your current experience? ";
                    cin >> exp;
                    result=650 - exp;
                    break;                  
                    case 8: cout << " What is your current experience? ";
                    cin >> exp;
                    result=801 - exp;
                    break;                  
                    case 9: cout << " What is your current experience? ";
                    cin >> exp;
                    result=969 - exp;
                    break;                  
                    case 10: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1154 - exp;
                    break;
                    case 11: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1358 - exp;
                    break;
                    case 12: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1584 - exp;
                    break;
                    case 13: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1833 - exp;
                    break;
                    case 14: cout << " What is your current experience? ";
                    cin >> exp;
                    result=2107 - exp;
                    break;
                    case 15: cout << " What is your current experience? ";
                    cin >> exp;
                    result=2411 - exp;
                    break;
                    case 16: cout << " What is your current experience? ";
                    cin >> exp;
                    result=2746 - exp;
                    break;
                    case 17: cout << " What is your current experience? ";
                    cin >> exp;
                    result=3115 - exp;
                    break;
                    case 18: cout << " What is your current experience? ";
                    cin >> exp;
                    result=3523 - exp;
                    break;
                    case 19: cout << " What is your current experience? ";
                    cin >> exp;
                    result=3973 - exp;
                    break;
                    case 20: cout << " What is your current experience? ";
                    cin >> exp;
                    result=4470 - exp;
                    break;
                    case 21: cout << " What is your current experience? ";
                    cin >> exp;
                    result=5018 - exp;
                    break;
                    case 22: cout << " What is your current experience? ";
                    cin >> exp;
                    result=5624 - exp;
                    break;
                    case 23: cout << " What is your current experience? ";
                    cin >> exp;
                    result=6291 - exp;
                    break;
                    case 24: cout << " What is your current experience? ";
                    cin >> exp;
                    result=7028 - exp;
                    break;
                    case 25: cout << " What is your current experience? ";
                    cin >> exp;
                    result=7842 - exp;
                    break;
                        case 26: cout << " What is your current experience? ";
                    cin >> exp;
                    result=8740 - exp;
                    break;
                    case 27: cout << " What is your current experience? ";
                    cin >> exp;
                    result=9730 - exp;
                    break;
                    case 28: cout << " What is your current experience? ";
                    cin >> exp;
                    result=10824 - exp;
                    break;
                    case 29: cout << " What is your current experience? ";
                    cin >> exp;
                    result=12031 - exp;
                    break;
                    case 30: cout << " What is your current experience? ";
                    cin >> exp;
                    result=13363 - exp;
                    break;
                    case 31: cout << " What is your current experience? ";
                    cin >> exp;
                    result=14833 - exp;
                    break;
                    case 32: cout << " What is your current experience? ";
                    cin >> exp;
                    result=16456 - exp;
                    break;
                    case 33: cout << " What is your current experience? ";
                    cin >> exp;
                    result=18247 - exp;
                    break;
                    case 34: cout << " What is your current experience? ";
                    cin >> exp;
                    result=20224 - exp;
                    break;
                    case 35: cout << " What is your current experience? ";
                    cin >> exp;
                    result=22406 - exp;
                    break;
                    case 36: cout << " What is your current experience? ";
                    cin >> exp;
                    result=24815 - exp;
                    break;
                    case 37: cout << " What is your current experience? ";
                    cin >> exp;
                    result=27473 - exp;
                    break;
                    case 38: cout << " What is your current experience? ";
                    cin >> exp;
                    result=30408 - exp;
                    break;
                    case 39: cout << " What is your current experience? ";
                    cin >> exp;
                    result=33648 - exp;
                    break;
                    case 40: cout << " What is your current experience? ";
                    cin >> exp;
                    result=37224 - exp;
                    break;
                    case 41: cout << " What is your current experience? ";
                    cin >> exp;
                    result=41171 - exp;
                    break;
                    case 42: cout << " What is your current experience? ";
                    cin >> exp;
                    result=45529 - exp;
                    break;
                    case 43: cout << " What is your current experience? ";
                    cin >> exp;
                    result=50339- exp;
                        break;
                    case 44: cout << " What is your current experience? ";
                    cin >> exp;
                    result=55649 - exp;
                    break;
                    case 45: cout << " What is your current experience? ";
                    cin >> exp;
                    result=61512 - exp;
                    break;
                    case 46: cout << " What is your current experience? ";
                    cin >> exp;
                    result=67983 - exp;
                    break;
                    case 47: cout << " What is your current experience? ";
                    cin >> exp;
                    result=75127 - exp;
                    break;
                    case 48: cout << " What is your current experience? ";
                    cin >> exp;
                    result=83014 - exp;
                    break;
                    case 49: cout << " What is your current experience? ";
                    cin >> exp;
                    result=91721 - exp;
                    break;
                    case 50: cout << " What is your current experience? ";
                    cin >> exp;
                    result=101333 - exp;
                    break;
                    case 51: cout << " What is your current experience? ";
                    cin >> exp;
                    result=111945 - exp;
                    break;
                    case 52: cout << " What is your current experience? ";
                    cin >> exp;
                    result=123660 - exp;
                    break;
                    case 53: cout << " What is your current experience? ";
                    cin >> exp;
                    result=136594 - exp;
                    break;
                    case 54: cout << " What is your current experience? ";
                    cin >> exp;
                    result=150872 - exp;
                    break;
                    case 55: cout << " What is your current experience? ";
                    cin >> exp;
                    result=166636 - exp;
                    break;
                    case 56: cout << " What is your current experience? ";
                    cin >> exp;
                    result=184040 - exp;
                    break;
                    case 57: cout << " What is your current experience? ";
                    cin >> exp;
                    result=203254 - exp;
                    break;
                    case 58: cout << " What is your current experience? ";
                    cin >> exp;
                    result=224466 - exp;
                    break;
                    case 59: cout << " What is your current experience? ";
                    cin >> exp;
                    result=247886 - exp;
                    break;
                    case 60: cout << " What is your current experience? ";
                    cin >> exp;
                    result=273742 - exp;
                    break;
                    case 61: cout << " What is your current experience? ";
                    cin >> exp;
                    result=302288 - exp;
                    break;
                    case 62: cout << " What is your current experience? ";
                    cin >> exp;
                    result=333804 - exp;
                    break;
                    case 63: cout << " What is your current experience? ";
                    cin >> exp;
                    result=368599 - exp;
                    break;
                    case 64: cout << " What is your current experience? ";
                    cin >> exp;
                    result=407015 - exp;
                    break;
                    case 65: cout << " What is your current experience? ";
                    cin >> exp;
                    result=449428 - exp;
                    break;
                    case 66: cout << " What is your current experience? ";
                    cin >> exp;
                    result=496254 - exp;
                    break;
                    case 67: cout << " What is your current experience? ";
                    cin >> exp;
                    result=547953 - exp;
                    break;
                    case 68: cout << " What is your current experience? ";
                    cin >> exp;
                    result=605032 - exp;
                    break;
                    case 69: cout << " What is your current experience? ";
                    cin >> exp;
                    result=668051 - exp;
                    break;
                    case 70: cout << " What is your current experience? ";
                    cin >> exp;
                    result=737627 - exp;
                    break;
                    case 71: cout << " What is your current experience? ";
                    cin >> exp;
                    result=814445 - exp;
                    break;
                    case 72: cout << " What is your current experience? ";
                    cin >> exp;
                    result=899257 - exp;
                    break;
                    case 73: cout << " What is your current experience? ";
                    cin >> exp;
                    result=992895 - exp;
                    break;
                    case 74: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1096278 - exp;
                    break;
                    case 75: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1210421 - exp;
                    break;
                    case 76: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1336443 - exp;
                    break;
                    case 77: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1475581 - exp;
                    break;
                    case 78: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1629200 - exp;
                    break;
                    case 79: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1798808 - exp;
                    break;
                    case 80: cout << " What is your current experience? ";
                    cin >> exp;
                    result=1986068 - exp;
                    break;
                    case 81: cout << " What is your current experience? ";
                    cin >> exp;
                    result=2192818 - exp;
                    break;
                    case 82: cout << " What is your current experience? ";
                    cin >> exp;
                    result=2421087 - exp;
                    break;
                    case 83: cout << " What is your current experience? ";
                    cin >> exp;
                    result=2673114 - exp;
                    break;
                    case 84: cout << " What is your current experience? ";
                    cin >> exp;
                    result=2951373 - exp;
                    break;
                    case 85: cout << " What is your current experience? ";
                    cin >> exp;
                    result=3258594 - exp;
                    break;
                    case 86: cout << " What is your current experience? ";
                    cin >> exp;
                    result=3597792 - exp;
                    break;
                    case 87: cout << " What is your current experience? ";
                    cin >> exp;
                    result=3972294 - exp;
                    break;
                    case 88: cout << " What is your current experience? ";
                    cin >> exp;
                    result=4385776 - exp;
                    break;
                    case 89: cout << " What is your current experience? ";
                    cin >> exp;
                    result=4842295 - exp;
                    break;
                    case 90: cout << " What is your current experience? ";
                    cin >> exp;
                    result=5346332 - exp;
                    break;
                    case 91: cout << " What is your current experience? ";
                    cin >> exp;
                    result=5902831 - exp;
                    break;
                    case 92: cout << " What is your current experience? ";
                    cin >> exp;
                    result=6517253 - exp;
                    break;
                    case 93: cout << " What is your current experience? ";
                    cin >> exp;
                    result=7195629 - exp;
                    break;
                    case 94: cout << " What is your current experience? ";
                    cin >> exp;
                    result=7944614 - exp;
                    break;
                    case 95: cout << " What is your current experience? ";
                    cin >> exp;
                    result=8771558 - exp;
                    break;
                    case 96: cout << " What is your current experience? ";
                    cin >> exp;
                    result=9684577 - exp;
                    break;
                    case 97: cout << " What is your current experience? ";
                    cin >> exp;
                    result=10692629 - exp;
                    break;
                    case 98: cout << " What is your current experience? ";
                    cin >> exp;
                    result=11805606 - exp;
                    break;
                    case 99: cout << " What is your current experience? ";
                    cin >> exp;
                    result=13034431 - exp;
                    case 100: cout << " What is your current experience? " <<endl;
                    cin >> exp;
                    result=14391160 - exp;
                    break;
                    default: exit(0);
                    }
                    cout << " Experience Needed: " << result  << endl;
// Ores needed to be mined to acquire the level up.
                    cout << " Rune Essence: " << ceil(result/5.0) << endl;
                    cout << " Clay: " << ceil(result/5.0) << endl;
                    cout << " Copper: " << ceil(result/17.5) << endl;
                    cout << " Tin: " << ceil(result/17.5) << endl;
                    cout << " Bluerite: " << ceil(result/17.5) << endl;
                    cout << " Iron: " << ceil(result/35.0) << endl;
                    cout << " Silver: " << ceil(result/40.0) << endl;
                    cout << " Coal: " << ceil(result/50.0) << endl;
                    cout << " Gold: " << ceil(result/65.0) << endl;
                    cout << " Mithril: " << ceil(result/80.0) << endl;
                    cout << " Adamant: " << ceil(result/ 95.0) << endl;
                    cout << " Runite: " << ceil(result/125.0) << endl;
                    cout << endl << endl << endl << "\t\t\tCreated by USDblades" << endl;
         return 0;
}

编辑:抱歉不清楚。我正在努力改进运行逃逸技能计算器的代码。我很好奇是否可以通过使用不同的函数来减少一些代码行。提供的代码是我的项目,我正在工作。你能回顾一下它并给我指点吗?

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2011-01-05 12:40:27

您的switch语句是不必要的。因为

代码语言:javascript
运行
复制
cout << " What is your current experience? ";
cin >> exp;

在所有情况下都是完全相同的代码,您可以将它移出switch (就在它之前)。在这些行之前,添加检查lvl是否在2到100范围内的代码,然后退出。然后,您将看到剩下的所有案例都是

代码语言:javascript
运行
复制
result = k - exp;

其中k是某个整数。创建一个包含101个元素的数组(因此索引从0到100),以保存k的所有可能值,并对其进行初始化:

代码语言:javascript
运行
复制
unsigned expToNextLevel[101] = {
    0, 0, 83, 174, 276, /* and so on */
};

然后你庞大的switch语句变成:

代码语言:javascript
运行
复制
if(lvl < 2 || lvl > 100)
    exit(0);

cout << " What is your current experience? ";
cin >> exp;
result = expToNextLevel[lvl] - exp;

您可以使用类似的技术将对象移动到数组中,以获取列出每种材料和矿石需求的cout行,并将其转换为for循环。

编程的基本技能之一是识别重复,并找到一种方法将其转换为循环或以其他方式简化它。你所写的代码被称为“意大利面条代码”,一个危险的信号是有大量的复制和粘贴。

每当您发现自己正在复制和粘贴代码时,都应该考虑“这应该是一个循环或函数”。在不同版本中更改的部分是需要作为函数参数或数组查找的部分。

票数 8
EN

Stack Overflow用户

发布于 2011-01-05 12:54:13

当你在重复的代码中看到很多“魔术数字”时,你应该问自己:有没有什么方法可以计算出这个数字?

事实证明,你可以计算出某个级别所需的经验量:

代码语言:javascript
运行
复制
unsigned int experienceNeeded(unsigned int level) {
    float needed = 0;
    for(unsigned int x = 1; x < level; ++x) {
        needed += ::floor(static_cast<float>(x) + 300 * ::pow(2, static_cast<float>(x)/7));
    }
    return static_cast<unsigned int>(::floor(needed / 4));
}

这消除了对整体式switch语句的需要。

票数 3
EN

Stack Overflow用户

发布于 2011-01-05 12:30:31

要学习编写好的代码,您可以做的最好的两件事是

  1. 写东西,并获得同行评审。
  2. 修复其他人的坏东西

通过这两个任务,您将学到很多东西。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4600798

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档