Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C#

จะลบรายการที่ซ้ำกันออกจากอาร์เรย์ที่เรียงลำดับและส่งคืนอาร์เรย์ที่ไม่ซ้ำโดยใช้ C # ได้อย่างไร


อาร์เรย์ได้รับการจัดเรียงแล้ว เราสามารถเก็บพอยน์เตอร์สองตัว ii และ jj โดยที่ ii เป็นตัววิ่งช้าในขณะที่ jj เป็นตัวเร่งความเร็ว ตราบใดที่ nums[i] =nums[j]nums[i]=nums[j] เราเพิ่ม jj เพื่อข้ามรายการที่ซ้ำกัน

เมื่อเราพบ nums[j] !=nums[i] การรันซ้ำได้สิ้นสุดลง ดังนั้นเราต้องคัดลอกค่าของมันไปที่ nums[i + 1]nums[i+1] ii จะเพิ่มขึ้นและเราทำซ้ำขั้นตอนเดิมอีกครั้งจนกระทั่ง jj ถึงจุดสิ้นสุดของอาร์เรย์ สร้างอาร์เรย์ใหม่ คัดลอกองค์ประกอบทั้งหมดจากอาร์เรย์ที่กรองจนถึงดัชนีและส่งคืนอาร์เรย์ใหม่

ความซับซ้อนของเวลา − O(N)

ตัวอย่าง

using System;
namespace ConsoleApplication{
   public class Arrays{
      public int[] RemoveDuplicatesFromSortedArrayAndReturnArray(int[] arr){
         int index = 1;
         for (int i = 0; i < arr.Length - 1; i++){
            if (arr[i] != arr[i + 1]){
               arr[index] = arr[i + 1];
               index++;
            }
            else{
               continue;
            }
         }
         int[] newarr = new int[index];
         for (int i = 0; i < index; i++){
            newarr[i] = arr[i];
         }
         return newarr;
      }
   }
   class Program{
      static void Main(string[] args){
         Arrays a = new Arrays();
         int[] arr = { 0, 0, 1, 1, 1, 2, 2, 3, 3, 4 };
         int[] res = a.RemoveDuplicatesFromSortedArrayAndReturnArray(arr);
         for (int i = 0; i < res.Length; i++){
            Console.WriteLine(res[i]);
         }
         Console.ReadLine();
      }
   }
}

ผลลัพธ์

0 1 2 3 4