ในปัญหานี้ เราได้รับ arr[] ขนาด n และจำนวนเต็ม a และ b สองจำนวน งานของเราคือ f ระบุองค์ประกอบเดียวที่ปรากฏขึ้น b ครั้ง .
ค่าทั้งหมดของอาร์เรย์เกิดขึ้นในช่วงเวลาหนึ่งยกเว้นค่าหนึ่งซึ่งเกิดขึ้น b ครั้งในอาร์เรย์และเราจำเป็นต้องค้นหาค่านั้น
มาดูตัวอย่างเพื่อทำความเข้าใจปัญหากัน
ป้อนข้อมูล
arr[] = {3, 3, 3, 3, 5, 5, 5, 1, 1,1,1} a = 4, b = 3 ผลผลิต
5
แนวทางการแก้ปัญหา
วิธีแก้ปัญหาอย่างง่ายคือการนับการเกิดขึ้นของแต่ละองค์ประกอบแล้วจัดเก็บไว้ในเมทริกซ์ 2 มิติ จากนั้นข้ามเมทริกซ์เพื่อหาค่าที่มีความถี่การเกิด b.
ความซับซ้อนของเวลาของวิธีนี้คือ O(N 2 ) แต่วิธีที่มีประสิทธิภาพมากกว่าที่สามารถแก้ปัญหาได้คือการหาผลรวมขององค์ประกอบเฉพาะทั้งหมดของอาร์เรย์แล้วคูณด้วย a จากนั้นลบผลรวมของอาร์เรย์ทั้งหมดออกจากค่านี้แล้วหารผลลัพธ์ด้วย (a-b) ค่าผลลัพธ์คือค่าที่เกิดความถี่ b.
ตัวอย่าง
โปรแกรมเพื่อแสดงการทำงานของโซลูชันของเรา
#include <bits/stdc++.h>
using namespace std;
int findbFreqVal(int arr[], int n, int a, int b){
unordered_set<int> uniqueVal;
int uniqueValSum = 0, arrSum = 0;
for (int i = 0; i < n; i++) {
if (uniqueVal.find(arr[i]) == uniqueVal.end()) {
uniqueVal.insert(arr[i]);
uniqueValSum += arr[i];
}
arrSum += arr[i];
}
uniqueValSum = a * uniqueValSum;
return ((uniqueValSum - arrSum) / (a - b));
}
int main(){
int arr[] = { 4, 4, 4, 31, 8, 8, 8, 5, 5, 5};
int a = 3, b = 1;
int n = sizeof(arr) / sizeof(arr[0]);
cout<<"The value of the array that appears b times is "<<findbFreqVal(arr, n, a, b);
return 0;
} ผลลัพธ์
The value of the array that appears b times is 31