• 0

Write a C++ program that takes as input six numbers (x, x1, x2, x3, x4, x5) then the program finds and prints the result of the following equation

1 شخص أعجب بهذا

انشر على الشّبكات الاجتماعية


رابط هذه المساهمة
شارك على الشبكات الإجتماعية
  • 0

السلام عليكم @وضاح حجاج

يمكنك القيام بذلك من خلال عمل ميثود تاخد مدخل المستخدم كنوع vector صنف int و قيمة حجم المصفوفة من نوع vector / اول عنصر فيها وهو 0  ويمكن القيام بذلك برمجياً هكذا 

نقوم بإستيراد المكتبات أولاً 

#include<bits/stdc++.h>
#include <iostream>
#include <vector>
using namespace std;

ثم نقوم بعمل الميثود التي ذكرناها فوق 

int findStuplets(vector<int> df, int n)
{

    int index = 0;
    int RHS[n*n*n + 1];
    for (int i = 0; i < n; i++)
      if (df[i]) 
        for (int j = 0; j < n; j++)
          for (int k = 0; k < n; k++)
            RHS[index++] = df[i] * (df[j] + df[k]);


    sort(RHS, RHS + n);
 
    int result = 0;
  
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            for(int k = 0; k < n; k++)
            {
                int val = df[i] * df[j] + df[k];
                result += (upper_bound(RHS, RHS + index, val) -
                          lower_bound(RHS, RHS + index, val));
            }
        }
    }
 
    return result;
}


 

ثم نقوم بأخد مدخلات المستخدم في الفنشكن الرئيسية وإستدعاء الميثود السابقة لطباعة النتيجة 

int main()
{
    int s;
   
    vector<int> df;
     
    for (int i = 0; df.size() < 6; i++) 
    {
        cin >> s;
        df.push_back(s); 
    }
    int n = sizeof(df)/sizeof(df[0]);
    std::cout << findSextuplets(df, n) << endl;
    std::cout << std::endl;
  
    return 0;
}

الشكل النهائي يصبح هكذا 

#include<bits/stdc++.h>
#include <iostream>
#include <vector>


using namespace std;


int findStuplets(vector<int> df, int n)
{

    int index = 0;
    int RHS[n*n*n + 1];
    for (int i = 0; i < n; i++)
      if (df[i]) 
        for (int j = 0; j < n; j++)
          for (int k = 0; k < n; k++)
            RHS[index++] = df[i] * (df[j] + df[k]);


    sort(RHS, RHS + n);
 
    int result = 0;
  
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            for(int k = 0; k < n; k++)
            {
                int val = df[i] * df[j] + df[k];
                result += (upper_bound(RHS, RHS + index, val) -
                          lower_bound(RHS, RHS + index, val));
            }
        }
    }
 
    return result;
}
 
int main()
{
    int s;
   
    vector<int> df;
     
    for (int i = 0; df.size() < 6; i++) 
    {
        cin >> s;
        df.push_back(s); 
    }
    int n = sizeof(df)/sizeof(df[0]);
    std::cout << findSextuplets(df, n) << endl;
    std::cout << std::endl;
  
    return 0;
}

انشر على الشّبكات الاجتماعية


رابط هذه المساهمة
شارك على الشبكات الإجتماعية

يجب أن تكون عضوًا لدينا لتتمكّن من التعليق

انشاء حساب جديد

يستغرق التسجيل بضع ثوان فقط


سجّل حسابًا جديدًا

تسجيل الدخول

تملك حسابا مسجّلا بالفعل؟


سجّل دخولك الآن