zoukankan      html  css  js  c++  java
  • 合并两个有序数组

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace ConsoleApplication8
    {
        class Program
        {
            static void Main(string[] args)
            {
                int[] a = { 11, 12, 66, 99 };
                int[] b = { 7, 8, 13, 44 };
    
                List<int> alist = new List<int>();
                List<int> blist = new List<int>();
                for (int i = 1; i <= 100 * 10000; i++)
                {
                    alist.Add(i);
                }
                for (int i = 1000001; i <= 200 * 10000; i++)
                {
                    blist.Add(i);
                }
                //a = alist.ToArray();
                //b = blist.ToArray();
                int[] c = MergeArr(a, b);
                for (int i = 0; i < c.Length; i++)
                {
                    Console.WriteLine(c[i]);
    
                }
                Console.Read();
            }
    
            private static T[] MergeArr<T>(T[] a, T[] b) where T : IComparable
            {
                List<T> arr = new List<T>();
                int maxIndex = a.Length - 1;
                bool ia = false;
                bool ib = false;
                int aindex = 0;
                int bindex = 0;
                while (true)
                {
    
                    if (aindex > maxIndex)
                    {
                        ia = true;
                        break;
                    }
                    if (bindex > maxIndex)
                    {
                        ib = true;
                        break;
                    }
    
                    if (a[aindex].CompareTo(b[bindex]) <= 0)
                    {
                        arr.Add(a[aindex]);
                        aindex++;
                    }
                    else
                    {
                        arr.Add(b[bindex]);
                        bindex++;
    
                    }
                }
    
                if (ia)
                {
                    for (int index = bindex; index <= maxIndex; index++)
                    {
                        arr.Add(b[index]);
                    }
                }
                if (ib)
                {
                    for (int index = aindex; index <= maxIndex; index++)
                    {
                        arr.Add(a[index]);
                    }
                }
                return arr.ToArray();
            }
        }
    }
  • 相关阅读:
    剑指 Offer 46. 把数字翻译成字符串
    leedcode:27. 移除元素
    1052. 爱生气的书店老板(滑动窗口)
    剑指 Offer 56
    剑指 Offer 11. 旋转数组的最小数字(二分)
    1919年巴黎和会顾维钧英语演讲稿
    状语从句
    定语从句
    名词性从句
    并列句
  • 原文地址:https://www.cnblogs.com/kexb/p/9261245.html
Copyright © 2011-2022 走看看