假设我们有一个字符串,称为源。它包含“纽约市 - 12A - 1234B”
以下是规则:
一种。我们知道,最接近字符串开头的两个数字应该与后面的字符一起保存到一个单独的字符串中,称为结果;
湾。我们不确定以下字符是数字还是字母
C。字符串本身的格式不同 - 它可能是“NY 12A 1234B”
d。我们可以不在乎其他任何事情!
现在我以我无限的智慧创造了这个怪物。它有效,但请告诉我有更好的方法来做到这一点,或者充其量是一种更清洁、更注重性能的方法。
class Program
{
public static int i = 0;
public static int q = 0;
public static int x = 0;
public static string source = "New York City - 12A - 1234B";
public static string results = "";
public static char[] from_source_char;
public static List<string> from_source_list = new List<string>();
static void Main(string[] args)
{
from_source_char = source.ToCharArray();
foreach (char unit in from_source_char)
{
from_source_list.Add(unit.ToString());
}
Console.WriteLine("Doing while " + i.ToString() + " < " + (from_source_list.Count() - 1).ToString());
while (i < from_source_list.Count() - 1)
{
Console.WriteLine("i is at " + i.ToString());
Console.WriteLine("Examining " + from_source_list[i].ToString());
try
{
q = Convert.ToInt32(from_source_list[i]);
results += from_source_list[i].ToString();
Console.WriteLine("Found part 1!");
x++;
}
catch
{
Console.WriteLine("Disregarding " + from_source_list[i].ToString());
// do nothing
}
if (x == 2)
{
Console.WriteLine("Found final part! " + from_source_char[i+1].ToString());
results += from_source_char[i+1].ToString();
break;
}
i++;
}
Console.WriteLine("Result is " + results.ToString());
Thread.Sleep(999999);
}
}