平均值的平均值,最大值,最小值,总和?

时间:2012-08-20 10:30:05

标签: c# asp.net asp.net-mvc

你好我得到了一个字符串数组,它们是我自己制作的格式为H:M:S:MS

的持续时间

示例字符串:

0:0:4:410
0:0:1:425
0:0:1:802
0:0:1:509
0:0:1:674
0:0:1:628
0:0:2:76

如何在arraylist中 sum / avg / min / max 这些项的值?

Arraylist名称为arrayLL

我是c#的新手,所以希望有人能告诉我如何使用字符串。

添加到数组的函数是:

if (Session["DT"].ToString() != "")
{
    TimeSpan ts = ((DateTime)Session["DT2"]).Subtract((DateTime)Session["DT"]);

    Session["TimeL"] = ts.Hours.ToString() + ":" 
                            + ts.Minutes.ToString() + ":"
                            + ts.Seconds.ToString() + ":" 
                            + ts.Milliseconds.ToString();
}

3 个答案:

答案 0 :(得分:2)

假设数字代表小时,分钟,秒和毫秒,您可以尝试以下操作:

// Empty list you will populate:
List<int> durationsInMilliseconds = new List<int>();

// Loop through your existing data, and calculate all
// durations into milliseconds:
foreach (string word in yourDurationArray)
{
    string[] values = s.Split(':');
    int hoursAsMilliseconds = Integer.parse(values[0]) * 60 * 60 * 1000;
    int minutesAsMilliseconds = Integer.parse(values[1]) * 60 * 1000;
    int secondsAsMilliseconds = Integer.parse(values[2]) * 1000;

    int sumDurationAsMilliseconds = hoursAsMilliseconds + 
                                    minutesAsMilliseconds + 
                                    secondsAsMilliseconds + 
                                    Integer.parse(values[3]);

    durationsInMilliseconds.add(sumDurationAsMilliseconds);
}

现在您应该有一个Integer类型列表(durationsInMilliseconds),其中包含单个可比较格式的数字。有了这个,你应该能够做任何你需要的计算。

(PS:如果您需要与原始输入数据格式相同的结果,则必须添加一个操作,以便从MS计算回小时,分钟和秒......)

答案 1 :(得分:1)

因为我猜他们是持续时间,所以我应该这样做

var enu_ts = yourvariable.OfType<string>().Select(x => 
             TimeSpan.Parse(x, @"h\:m\:s\:fff", CultureInfo.InvariantCulture));

最高

var max = enu_ts.Max().ToString();

最小

var max = enu_ts.Min().ToString();

答案 2 :(得分:1)

foreach(string s in dateString)
{
   spanList[i] = TimeSpan.Parse(s);
   total=total.Add(spanList[i++]);
}

Response.Write("Max TimeSpan:"+spanList.Max<TimeSpan>());
Response.Write("Min TimeSpan:" + spanList.Min<TimeSpan>());
Response.Write("Total Sum of TimeSpan:"+total);