إنتبه
هذا التمرين مهم جداً لأنك ستتعلم منه طريقة جديدة تجعلك تحصل على الـ Factorial للعدد بكود أقل.
المطلوب
أكتب برنامج يطلب من المستخدم إعطائه عدد صحيح و يخزنه في المتغير N.
ثم يقوم بحساب ناتج جمع جميع الأرقام من 1 إلى N كما في الصورة التالية.
إرشادات
المتغير
Sهو المتغير الذي سيحتوي على مجموع كل الأرقام الموجودة من 1 إلىN.الـ
iهو المتغير ( العداد ) الذي يزيد واحد في كل دورة.الـ
Fهو المتغير الذي نخزن فيه الـ Factorial لقيم العدادi.الـ
Nهو المتغير الذي يخزن العدد الذي سيدخله المستخدم و الذي تتوقف عنده الحلقة.الحلقة تبدأ من 1 و تتوقف عند
N, أي عند العدد الذي أدخله المستخدم.
كود الجافا
import java.util.Scanner;
public class Factorial_Sum {
public static void main (String[] args) {
Scanner input = new Scanner(System.in);
int N;
int F = 1;
double S = 0;
System.out.print("Enter a number For N : ");
N = input.nextInt();
for (int i=1; i <=N; i++)
{
F = F * i;
S = S + F;
}
System.out.print("S = " +S+ "\n");
}
}
شرح الكود
الهدف من هذا السؤال, إعطائك أفضل طريقة للحل بأصغر كود ممكن.
int N; int F = 1; double S = 0;
هنا قمنا بتجهيز المتغير N لتخزين الرقم الذي سيدخله المستخدم.
و المتغير F لتخزين الـ Factorial لكل قيمة من قيم العداد i الذي سنستخدمه في الحلقة.
و المتغير S لتخزين المجموع النهائي.
System.out.print("Enter a number for N: ");
N = input.nextInt();
هنا طلبنا من المستخدم إدخال عدد, ثم وضعناه في المتغير N.
for (int i=1; i <=N; i++)
{
F = F * i;
S = S + F;
}
هنا في كل دورة من دورات الحلقة i سيحدث التالي:
سيتم ضرب قيمة المتغير
Fبقيمة العدادiالحالية و تخزين الناتج في المتغيرF.
بهذه الطريقة سيحتوي المتغيرFعلى قيمة الـ Factorial للعدادiفي كل دورة.بعد أن أصبحت قيمة الـ Factorial للعداد
iمخزنة في المتغيرF, سيتم إضافتها على قيمة المتغيرS.
System.out.print("S = " +S+ "\n");
في الأخير سيتم عرض نتيجة جمع قيم الـ Factorials المخزنة في المتغير S.





محرر الويب
نظام الألوان
محول الوحدات
محلل عناوين الشبكات