如果输入Q或q,需要关闭程序。
但此刻它不会关闭并显示电话号码并关闭。
如果你能帮助我,请发帖谢谢你!
到目前为止,我目前已经有了这个代码并且它可以工作,但是while循环我没有,因为如果返回-5则它不会停止。
#include <iostream>
#include <string>
#include <iomanip>
using namespace std;
int readDial ( char &d1, char &d2, char &d3, char &d4, char &d5, char &d6, char &d7, char &d8);
char toDigit (char &d);
void acknowledgeCall (char d1, char d2, char d3, char d4, char d5, char d6, char d7, char d8);
int main ()
{
char d1, d2, d3, d4 , d5, d6, d7, d8;
int returnV = false;
while (returnV != -5)
{
returnV = readDial (d1,d2,d3,d4,d5,d6,d7,d8);
switch (returnV)
{
case -1: cout << "Error - An invalid Character was entered.\n";
case -2: cout << "Error - Phone Number cannot begin with 0.\n";
case -3: cout << "Error - Phone Number cannot begin with 555.\n";
case -4: cout << "Error - Hyphen is not in the correct spot.\n";
default: acknowledgeCall (d1, d2, d3,d4, d5,d6,d7,d8);
}
}
system("pause");
return 0;
}
int readDial ( char &d1, char &d2, char &d3, char &d4, char &d5, char &d6, char &d7, char &d8)
{
int returnV;
cout << " Enter The Phone Number (Q to Quit): ";
cin >> d1;
if( d1 == 'Q' || d1 == 'q')
return -5;
cin >> d2 >> d3 >> d4 >> d5 >> d6 >> d7 >> d8;
returnV = toDigit(d1);
if (returnV == -1)
return returnV;
returnV = toDigit(d2);
if (returnV == -1)
return returnV;
returnV = toDigit(d3);
if(d4 != '-')
return -4;
returnV = toDigit(d5);
if (returnV == -1)
return returnV;
returnV = toDigit(d6);
if (returnV == -1)
return returnV;
returnV = toDigit(d7);
if (returnV == -1)
return returnV;
returnV = toDigit(d8);
if (returnV == -1)
return returnV;
if (d1 == '0')
return -2;
if (d1 == '5' && d2 == '5' && d3 == '5')
return -3;
return 0;
}
char toDigit (char &d)
{
d = toupper (d);
switch (d)
{
case '0': case '1' : case '2' : case '3': case '4' : case '5' : case '6' : case '7' : case '8' : case '9':
break ;
case 'A' : case 'B' : case 'C':
d = '2';
break;
case 'D' : case 'E' : case 'F' :
d = '3';
break ;
case 'G' : case 'H' : case 'I' :
d = '4';
break ;
case 'J' : case 'K' : case 'L' :
d = '5';
break ;
case 'M' : case 'N' : case 'O' :
d = '6';
break ;
case 'P' : case 'Q' : case 'R' : case 'S' :
d = '7' ;
break ;
case 'T' : case 'U' : case 'V' :
d = '8' ;
break ;
case 'W' : case 'X' : case 'Y' : case 'Z' :
d = '9' ;
break;
default: return -1;
}
}
void acknowledgeCall (char d1, char d2, char d3, char d4, char d5, char d6, char d7, char d8)
{
cout << " Phone Number Dialed: " << d1 << d2 << d3 << d4 << d5 << d6 << d7 <<d8 << " \n\n ";
}
答案 0 :(得分:0)
你的main()中存在一个主要的逻辑问题。
检查switch:case
逻辑并为Q / q输入添加必要的处理
答案 1 :(得分:0)
您在切换案例中使用了default
个案,这意味着该案例适用于除上述值之外的所有其他值。因此,如果您未指定returnV=5
,则会执行默认情况。所以在默认情况之前添加此语句:
case -5: exit(1)
如果returnV为-5,这将导致程序退出。
并且在switch中的case之间使用break语句会导致控件在执行单个case后离开switch-case。如果您不使用,则执行原始案例之后的所有案例。因此,在每个案例的末尾添加break;