问题是我不确定如何正确格式化代码,以便当用户输入状态缩写时,main 方法会在 GetValidState 方法中查找它,让用户知道他们输入的内容是否有效。关键的事情之一是缩写必须有 2 个字母长。
static void Main(string[] args)
{
string stateAbbreviation;
bool fieldValidationSuccess = false;
promt = GetValidState("State (2 letters):t");
stateAbbreviation = ReadLine();
}
public static string GetValidState(string prompt, string[] sortedStateArray)
{
string[] states = new string[] { "AK", "WA", "OR", "CA", "AZ", "NM", "CO", "UT" };
fieldValidationSuccess = false;
while (!fieldValidationSuccess)
{
int sub = 0;
while (sub < states.Length && !fieldValidationSuccess)
{
if (states[sub].ToUpper() == stateAbbreviation.ToUpper())
{
fieldValidationSuccess = true;
}
else
{
sub++;
}
}
if (!fieldValidationSuccess)
{
WriteLine("n***ERROR. We do not ship to {0}.", stateAbbreviation);
}
}
}
- 在 Main(( 中初始化状态数组。
• 构建验证循环以确保用户输入有效的状态缩写。
• 使用循环在数组中搜索有效状态。不要使用 Array.BinarySearch
• 调用 GetValidString 以从用户处获取字符串。使用 2 作为最小和最大参数。
我不确定这是否是你想要的。你想要一个代码来检查状态是否在你的数组中?
public static void GetValidState(string prompt, string state)
{
string[] states = new string[] { "AK", "WA", "OR", "CA", "AZ", "NM", "CO", "UT" };
if (!states.Contains(state))
WriteLine("n***ERROR. We do not ship to {0}.", state);
}