首頁 > 後端開發 > C++ > C++程式在陣列中搜尋特定值

C++程式在陣列中搜尋特定值

WBOY
發布: 2023-08-30 19:21:06
轉載
985 人瀏覽過

C++程式在陣列中搜尋特定值

假設我們有一個陣列“arr”,其中包含 n 個已排序的整數值。我們也得到了一個大小為 q 的陣列“query”,我們必須告訴“query”中的值是否存在於給定數組“arr”中。如果查詢中的值存在於 arr 中,則列印「存在」以及該值所在的位置。否則,我們列印「不存在」並列印 arr 中的位置,其中最小值大於中的值查詢位於。我們必須記住,陣列是 1 索引的。

因此,若輸入類似n = 8, arr = {1, 2, 3, 4, 7, 9, 12, 15} , q = 3, query = {1, 5, 8},則輸出為

Present 1
Not present 5
Not present 6
登入後複製
登入後複製

查詢的第一個值出現在arr 的位置1 中。

查詢的第二個值出現在 arr 中。大於query中的值的最小值的位置是5。

同理,arr中也沒有query的第三個值。大於它的值位於 arr 的位置 6。

為了解決這個問題,我們將按照以下步驟操作-

  • 定義一個陣列值
  • 對於初始化i := 0,當i < n 時,更新(將i 增加1),執行-< n 时,更新(将 i 增加 1),执行 -
    • 在值末端插入arr[i]
  • 初始化i := 0,當i < q 時,更新(將i 增加1),執行-< q 时,更新(将 i 增加 1),执行 -
    • idx : = (values中不小於query[i]的第一個元素的位置) -values中第一個元素的位置
    • 如果values[idx]與query[i]相同,則-
      • print("存在")
    • 否則,
      • print("不存在")
    • print(idx 1)

#範例

讓我們請參考以下實作以獲得更好的理解-

#include <vector>
#include <iostream>
using namespace std;

void solve(int n, int arr[], int q, int query[]) {
   vector<int> values;
   for(int i = 0; i < n; i++){
      values.push_back(arr[i]);
   }
   for(int i = 0; i < q; i++) {
      int idx = lower_bound (values.begin(), values.end(),
      query[i]) - values.begin();
      if (values[idx] == query[i])
         cout << "Present ";
      else
         cout << "Not present ";
      cout << idx + 1 << endl;
   }
}
int main() {
   int input_arr[] = {1, 2, 3, 4, 7, 9, 12, 15};
   int query_arr[] = {1, 5, 8};
   solve(8, input_arr, 3, query_arr);
   return 0;
}
登入後複製

輸入(標準輸入)

int input_arr[] = {1, 2, 3, 4, 7, 9, 12, 15};
int query_arr[] = {1, 5, 8};
solve(8, input_arr, 3, query_arr);
登入後複製

輸出

Present 1
Not present 5
Not present 6
登入後複製
登入後複製

以上是C++程式在陣列中搜尋特定值的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板