使用 "a" 变量对数字进行排序

Sort the numbers with "a" variable

我有这样的问题。
我把列表中的所有数字排序,打印在listBox中。我从我制作数组的 txt 文件中读取数字。
我需要用户按以下顺序输入任何数字(我将其保存在变量“a”中):

并将其全部打印在列表框中。

...
float x;
if (float.TryParse(value, NumberStyles.Number, CultureInfo.InvariantCulture, out x))
{
    lst.Items.Add(x);
}
List<float> array = new List<float>();
array.Add(x);
a = Convert.ToInt32(txt1.Text);
int at = lst2.Items.Count;
for (int o = 0; o < lst2.Items.Count; ++o)
{
    if (x < (float)(lst2.Items[o]) && a >= o)
    {
        at = o;
        break;
    }
}
lst2.Items.Insert(at, x);

使用此代码,我只对数字进行排序,而不使用变量进行排序。

您可以只获取小于、等于和大于 a 的数字,然后填充列表框。

private List<float> numbers = new List<float>();

private void Form1_Load(object sender, EventArgs e)
{
    numbers = File.ReadAllLines("input.txt").Select(s => float.Parse(s)).ToList();
}

private void button1_Click(object sender, EventArgs e)
{
    if (float.TryParse(txt1.Text, NumberStyles.Number, CultureInfo.InvariantCulture, out float a))
    {
        // add a to numbers?
        numbers.Add(a);
        var lessThan = numbers.Where(n => n < a);
        var equalTo = numbers.Where(n => n == a);
        var greaterThan = numbers.Where(n => n > a);
        // populate listboxes?
        lst.DataSource = lessThan.ToList();
        lst1.DataSource = equalTo.ToList();
        lst2.DataSource = greaterThan.ToList();
    }
}

input.txt

123.45
1.2345
0.12345
12345
12.345
1234.5

如果你想让它们全部排序,你可以在读取文件时使用OrderBy

numbers = File.ReadAllLines("input.txt").Select(s => float.Parse(s)).OrderBy(n => n).ToList();