Rumah >pembangunan bahagian belakang >C++ >Operasi tatasusunan dan jumlah menggunakan C/C++

Operasi tatasusunan dan jumlah menggunakan C/C++

PHPz
PHPzke hadapan
2023-09-02 22:29:061374semak imbas

Operasi tatasusunan dan jumlah menggunakan C/C++

Di sini kita akan melihat masalah, dengan mengandaikan array diberikan. Terdapat n elemen. Satu lagi nilai S juga diberikan. Kita mesti mencari elemen K dalam tatasusunan supaya jika semua elemen yang lebih besar daripada K adalah sama dengan K, maka jumlah semua elemen tatasusunan akhir sama dengan S. Jika tidak boleh, maka -1 dikembalikan.

Katakan elemen ialah {12, 6, 3, 7, 8} dan nilai hasil tambah ialah 15, maka keluarannya ialah 3. Tatasusunan akhir ialah {3, 3, 3, 3, 3}, dan jumlah elemen tatasusunan ialah S = 15

Algoritma

getVal(arr, n, S)

Begin
   sort arr as increasing order
   sum := 0
   for i in range 0 to n-1, do
      if sum + (arr[i] * (n - i)) is same as S, then
         return arr[i]
      end if
      sum := sum + arr[i]
   done
   return -1
End

Contoh

rreee Output

#include <iostream>
#include <algorithm>
using namespace std;
int getVal(int arr[], int n, int S) {
   sort(arr, arr + n);
   int sum = 0;
   for (int i = 0; i < n; i++) {
      if (sum + (arr[i] * (n - i)) == S) //if current value is satisfying, then return arr[i]
         return arr[i];
      sum += arr[i];
   }
   return -1;
}
int main() {
   int S = 15;
   int arr[] = { 12, 3, 6, 7, 8 };
   int n = sizeof(arr) / sizeof(arr[0]);
   cout << getVal(arr, n, S);
}

Atas ialah kandungan terperinci Operasi tatasusunan dan jumlah menggunakan C/C++. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:tutorialspoint.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Artikel sebelumnya:Program C untuk jenis radixArtikel seterusnya:Program C untuk jenis radix