123-xiaoming 2020-07-02 09:28 采纳率: 25%
浏览 399
已采纳

C#中,在一个数组中检索在另一个数组,如果存在返回数组的位置,如果不存在返回-1,如何实现?

C# 实现

例如
byte[] newbyte=new byte[]{0x7E,0x20,0x30,0x2F,0x19,0x2C};
byte[] b=new byte[]{0x20,0x30};
检索数组b在数组newbyte中的位置,
理论上应该返回1

有什么方法可以实现这个功能吗?

  • 写回答

1条回答 默认 最新

  • qq_28838019 2020-07-02 10:37
    关注

    static int search(byte[] haystack, byte[] needle)
    {
    for (int i = 0; i <= haystack.Length - needle.Length; i++)
    {
    if (match(haystack, needle, i))
    {
    return i;
    }
    }
    return -1;
    }

    static bool match(byte[] haystack, byte[] needle, int start)
    {
    if (needle.Length + start > haystack.Length)
    {
    return false;
    }
    else
    {
    for (int i = 0; i < needle.Length; i++)
    {
    if (needle[i] != haystack[i + start])
    {
    return false;
    }
    }
    return true;
    }
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 微服务假死,一段时间后自动恢复,如何排查处理
  • ¥15 cplex运行后参数报错是为什么
  • ¥15 之前不小心删了pycharm的文件,后面重新安装之后软件打不开了
  • ¥15 vue3获取动态宽度,刷新后动态宽度值为0
  • ¥15 升腾威讯云桌面V2.0.0摄像头问题
  • ¥15 关于Python的会计设计
  • ¥15 聚类分析 设计k-均值算法分类器,对一组二维模式向量进行分类。
  • ¥15 stm32c8t6工程,使用hal库
  • ¥15 找能接spark如图片的,可议价
  • ¥15 博通raid 的写入速度很高也很低