Добавление кода города в программу

По сути, я получил эту программу за одно задание. Он запрашивает любые телефонные номера длиной 7 цифр, например, 930-1892. тогда он скажет ваши цифры в качестве вывода. Теперь я решил, что предпочел бы добавить код города к 7 цифрам, всего до 10 цифр. Я хочу вывести его в формате, подобном (505)123-4567.

Я удивительно борюсь с этим, я не могу заставить программу выводить 10 цифр, включая код города, а не только 7 цифр. Но программа, как и сейчас, должна скомпилировать, запустить и вывести 7-значный номер телефона, к которому вы добавили.

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

/* Global Variables */
int prefix[3];
int number[4];
string phoneNumber;

// main routine
int main()
{
  // local variables
  int input_done = 0; // flag to control input loop
  int ascii_0 = 48;
  int i = 0;

  while (input_done == 0)
  {
    // Ask the user for input
    cout << "Please enter your 7 digit phone number (for example: 123-4567)" << endl;
    getline(cin, phoneNumber);

    // split up the input and check it for validity
    if (phoneNumber.length()==8)
    {
      input_done = 1;  // assume number is correct until otherwise

      for (i = 0; i <= 7; i++)
      {
        if (i == 3)
        {
          if (phoneNumber[3] != '-')
            input_done = 0;
        }
        else
        {
          if ( (phoneNumber[i] < '0') || (phoneNumber[i] > '9') )
            input_done = 0;
        }
      }

      // assign values to individual array elements if checked out okay
      if (input_done == 1)
      {
        for (i = 0; i <= 2; i++)
        {
          prefix[i] = phoneNumber[i] - ascii_0;
          number[i] = phoneNumber[i+4] - ascii_0;
        }
        number[3] = phoneNumber[7] - ascii_0;
     }
    }

    if (input_done != 1)
      cout << "There is a problem with what you entered, please try again.\n";

  }

  // report
  cout << "I have your phone number as: ";

  for (i = 0; i<3; i++)
    cout << prefix[i];
  cout << "-";
  for (i = 0; i<4; i++)
    cout << number[i];
  cout << endl;

  return 0;
}

1 ответ

Решение

Сначала есть несколько незначительных проблем с подходом, который вы выбрали. Сначала вы используете много магических чисел, что делает ваш код сложным для поддержки и развития, так как вам нужно беспокоиться об обновлении большего количества кода, увеличивая вероятность появления ошибок. Во-вторых, нет необходимости конвертировать телефонный номер в отдельные номера, это просто усложняет управление значениями в долгосрочной перспективе. Вы также ожидаете, что дефис будет находиться в определенном месте, снова используя магические числа, которые затруднят добавление поддержки кодов городов. Следующий подход исключает использование магических чисел, а также использование индексов и массивов и использует преимущества итераторов.

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

// main routine
int main()
{
    // local variables
    bool isValidNumber = false;
    string phoneNumber;

    while (isValidNumber == false)
    {
        // Ask the user for input
        cout << "Please enter your 10 digit phone number (i.e. 900-976-8008)" << endl;
        std::getline(cin, phoneNumber);

        isValidNumber = true;

        //  Validate and clean up the phone number
        for (std::string::iterator it = phoneNumber.begin(); it != phoneNumber.end();)
        {
            //  Check for characters we want to ignore
            if (*it == '(' || *it == ')' || *it == '-' || *it == ' ')
            {
                it = phoneNumber.erase(it);
            }
            //  Check for numbers since we really want to keep them
            else if (*it >= '0' || *it <= '9')
            {
                ++it;
            }
            //  Check characters that are considered invalid
            else
            {
                isValidNumber = false;
            }
        }

        //  Make sure the number of required digits are present. Add an additional
        //  check for numbers without area codes if you like.
        if (phoneNumber.size() != 10)
        {
            isValidNumber = false;
        }

        if (isValidNumber == false)
        {
            cout << "There is a problem with what you entered, please try again.\n";
        }
    }


    //  Split the number and print it
    std::string areacode;
    std::string prefix;
    std::string number;

    areacode = phoneNumber.substr(0, 3);
    prefix = phoneNumber.substr(3, 3);
    number = phoneNumber.substr(7, 4);

    std::cout
        << "I have your phone number as: ("
        << areacode
        << ") "
        << prefix
        << '-'
        << number
        << '\n';

    return 0;
}

Я также рекомендую не размещать using namespace std заявления в области имен. Это просто плохая форма и может привести к конфликтам имен.

Другие вопросы по тегам