C#练习题答案: 大多数数字【难度:1级】--景越C#经典编程题库,1000道C#基础练习题等你来挑战

大多数数字【难度:1级】:

答案1:

using System.Linq;
public class Kata
{
    public static int FindLongest(int[] N)
    {
        return N.OrderByDescending(X => X.ToString().Length).First();
    }
}

答案2:

using System.Linq;
using System;
public class Kata
{
  public static int FindLongest(int[] number)
    => number.Aggregate(0, (s,n)=> $"{s}".Length < $"{n}".Length ? n : s);
}

答案3:

using System.Linq;
public class Kata
{
  public static int FindLongest(int[] number)
  {
    int i = number.Max();
    foreach(int n in number)
    {
      if(n.ToString().Length == i.ToString().Length)
        return n;
    }
    return i;
  }
}

答案4:

public class Kata
{
  public static int FindLongest(int[] number)
  {
    int max = number[0].ToString().Length, temp, result = number[0];
    for (int i = 1; i < number.Length; i++)
    {
      temp = number[i].ToString().Length;
      if (temp > max)
        {
          max = temp;
          result = number[i];
        }
        else continue;
    }
    return result;
  }
}

答案5:

using System;
using System.Linq;

public static class Kata
{
  public static int FindLongest(int[] numbers)
    => numbers.Select((x, i) => Tuple.Create(x.ToString().Length, -i, x)).Max().Item3;
}

答案6:

using System;
using System.Linq;

public class Kata
{
  public static int FindLongest(int[] number)
  {
    return number
            .GroupBy(n => n.ToString().Length)
            .OrderByDescending(g => g.Key)
            .FirstOrDefault()
            .FirstOrDefault();
  }
}

答案7:

using System.Linq;

public class Kata
{
  public static int FindLongest(int[] number)
  {
     return number.GroupBy(x=>x.ToString().Length).Select(x=>x.First()).OrderByDescending(x=>x).FirstOrDefault();
  }
}

答案8:

using System.Linq;
public class Kata
{
    public static int FindLongest(int[] number)
    {
        var len = number.Max().ToString().Length;
        foreach (var v in number)
            if (v.ToString().Length == len)
                return v;
        return 0;
    }
}

答案9:

public class Kata
{
  public static int FindLongest(int[] number)
  {
    int longest = 0;
    int highCount = 0;
    foreach(int x in number){
      int y = x;
      int count = 0;
      while(y >= 10){
        y = y / 10;
        count++;
      }
      if(count > highCount){
        highCount = count;
        longest = x;
      }
    }
    return longest;
  }
}

答案10:

public class Kata
{
  public static int FindLongest(int[] number)
  {
    int largestNumber = 0;
    foreach (int entry in number)
    {
      if (entry.ToString().Length > largestNumber.ToString().Length)
      largestNumber = entry;
    }
    return largestNumber;
  }
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值