大佬教程收集整理的这篇文章主要介绍了c – 这些被认为是魔术数字吗?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
在下面的函数中,我的数组索引器是否会被视为幻数?
码:
String CalcGrade(int s1,int s2,int s3,double median) { const int SIZE = 23; const int LETTER_GRADE_BARRIERS[SIZE] = { 400,381,380,361,360,341,340,321,320,301,300,281,280,261,260,241,240,221,220,201,200,181,180 }; double finalGrade; String letterGrade; finalGrade = s1 + s2 + s3 + median; if (finalGrade >= LETTER_GRADE_BARRIERS[1] && finalGrade <= LETTER_GRADE_BARRIERS[0]) { letterGrade = "A"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[3] && finalGrade <= LETTER_GRADE_BARRIERS[2]) { letterGrade = "A-"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[5] && finalGrade <= LETTER_GRADE_BARRIERS[4]) { letterGrade = "B+"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[7] && finalGrade <= LETTER_GRADE_BARRIERS[6]) { letterGrade = "B"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[9] && finalGrade <= LETTER_GRADE_BARRIERS[8]) { letterGrade = "B-"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[11] && finalGrade <= LETTER_GRADE_BARRIERS[10]) { letterGrade = "C+"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[13] && finalGrade <= LETTER_GRADE_BARRIERS[12]) { letterGrade = "C"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[15] && finalGrade <= LETTER_GRADE_BARRIERS[14]) { letterGrade = "C-"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[17] && finalGrade <= LETTER_GRADE_BARRIERS[16]) { letterGrade = "D+"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[19] && finalGrade <= LETTER_GRADE_BARRIERS[18]) { letterGrade = "D"; } else if (finalGrade >= LETTER_GRADE_BARRIERS[21] && finalGrade <= LETTER_GRADE_BARRIERS[20]) { letterGrade = "D-"; } else if (finalGrade <= LETTER_GRADE_BARRIERS[22]) { letterGrade = "Fail"; } return letterGrade; }
谢谢!
除非你是@L_607_3@真正的大师,否则你可能也被允许自由使用两个权力:-)
String CalcGrade (int s1,double median) { // Grade lookup arrays. If grade is >= limit[n],String is grades[n]. // Anything below D- is a fail. static const int Limits[] = {400,180 }; static const int Grades[] = {"A+","A","A-","B+","B","B-","C+","C","C-","D+","D","D-"}; double finalGrade = s1 + s2 + s3 + median; // check each element of the array and,if the final grade is greater // than or equal to,return the grade String. for (int i = 0; i < sizeof(Limits) / sizeof(*Limits); i++) if (finalGrade >= Limits[i]) return Grades[i]; // Otherwise,Failed. return "Fail"; }
这将删除遍布代码的魔术数字到@L_607_3@区域,在这个区域中,它们的工作方式很明显(假设您很好地对齐它们).
它还消除了原始解决方案的@L_607_3@问题,即我们对得分为380.5的人做了什么 – 失败那些人并不公平:-)或者为400以上的人分配@L_607_3@等级(因为那里没有)看起来似乎是回归“A”的一种方式.
以上是大佬教程为你收集整理的c – 这些被认为是魔术数字吗?全部内容,希望文章能够帮你解决c – 这些被认为是魔术数字吗?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。