לוגו אתר Fresh          
 
 
  אפשרות תפריט  ראשי     אפשרות תפריט  צ'אט     אפשרות תפריט  מבזקים     אפשרות תפריט  צור קשר     חץ שמאלה ‎print ‎"Hello World!"; if‎ ‎not rules.‎know ‎then rules.‎read(); חץ ימינה  

לך אחורה   לובי הפורומים > מחשבים > תכנות ובניית אתרים
שמור לעצמך קישור לדף זה באתרי שמירת קישורים חברתיים
תגובה
 
כלי אשכול חפש באשכול זה



  #1  
ישן 21-01-2007, 21:31
  דרנט82 דרנט82 אינו מחובר  
 
חבר מתאריך: 10.01.07
הודעות: 15
שאלה בסיסית בC#

שלום,
ניסיתי לחפש מספר במערך באמצעות חיפוש בינארי. לא מופיעות לי שגיאות הידור אך המספר לא נמצא.
ניסיתי לפתור כך:



Console.WriteLine("enter a number");
int num = int.Parse(Console.ReadLine());
int[] arr = new int[5] { 3, 67, 4, 4, 17 };
printarr(arr);
Console.WriteLine("****");
bubbles(arr);
printarr(arr);
findarr(arr, num);
}
static void bubbles(int[] arr)
{
int temp = 0;
for (int i = 1; i < arr.Length; i++)
{
for (int j = 0; j < arr.Length - i; j++)
{
if (arr[j] > arr[j + 1])
{
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;

}

}
}
return;


}
static void printarr(int[] arr)
{
for (int i = 0; i < arr.Length; i++)
{
Console.WriteLine(arr[i]);
}
return;
}

static void findarr(int[] arr, int num)
{
int div = 0, j = 0, count = 0, index = 0, i = arr.Length - 1;
while (j > i)
{
div = (j + i) / 2;
if (num == arr[div])
{
count++;
index = div;
}
else if (num > arr[div])
{
j = div;

}
else
{
i = div;

}

}
if (num == arr[div])
{
Console.WriteLine("the num {0} appears in index {1} {2} times", num, div, count);
}
else
{
Console.WriteLine("not found");


}

אשמח אם תעזרו לי לפתור את התרגיל , תודה
דבר נוסף, איך אבדוק כהמ פעמים המספר מופיע?
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #3  
ישן 22-01-2007, 15:17
  דרנט82 דרנט82 אינו מחובר  
 
חבר מתאריך: 10.01.07
הודעות: 15
תיקון טעות
בתגובה להודעה מספר 2 שנכתבה על ידי or171 שמתחילה ב "אני לא בטוח אבל נראה לי..."

הפיתרון שלי הוא:
int[] arr = newint[10];

int[] arrf = newint[10];

Console.WriteLine("enter a number");

int num = int.Parse(Console.ReadLine());



initarrf (arr);

printarr(arr);



Console.WriteLine("****");

sortarr (arr);

printarr(arr);

findarr (arr,num);



}

staticvoid initarrf (int []arr)

{

Random rnd = newRandom();

for (int i = 0; i < arr.Length; i++)

{



arr[i] = rnd.Next(0, 100);



}

return;

}

staticvoid printarr (int []arr)

{

for (int i = 0; i < arr.Length; i++)

{

Console.WriteLine (arr[i]);



}

return;



}

staticvoid sortarr (int[]arr)

{

int temp=0;

for (int i=0;i<arr.Length-1;i++)

{

for (int j=i+1;j<arr.Length;j++)

{

if (arr[i]>arr[j])

{

temp=arr[i];

arr[i]=arr[j];

arr[j]=temp;



}

}

}

return;



}

staticvoid initarrf (int []arrf,int num,int []arr)

{

for (int i=0;i<arrf.Length;i++)

{

arrf[i]=-2;

}

}



staticvoid findarr (int []arr,int num)

{

int div = 0;

int i=0,j=arr.Length-1;

while (i < j)

{

div=(i + j) / 2;

if (num == arr[div])

{

break;

}

if (num >arr[div])

{

i = div ;

div++;

}

else

{

j = div;



}



}



if (num == arr[div])

{

Console.WriteLine("found! {0};",div);

}

else

{

Console.WriteLine("not found");

}



}



}

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

כלי אשכול חפש באשכול זה
חפש באשכול זה:

חיפוש מתקדם
מצבי תצוגה דרג אשכול זה
דרג אשכול זה:

מזער את תיבת המידע אפשרויות משלוח הודעות
אתה לא יכול לפתוח אשכולות חדשים
אתה לא יכול להגיב לאשכולות
אתה לא יכול לצרף קבצים
אתה לא יכול לערוך את ההודעות שלך

קוד vB פעיל
קוד [IMG] פעיל
קוד HTML כבוי
מעבר לפורום



כל הזמנים המוצגים בדף זה הם לפי איזור זמן GMT +2. השעה כעת היא 03:44

הדף נוצר ב 0.04 שניות עם 12 שאילתות

הפורום מבוסס על vBulletin, גירסא 3.0.6
כל הזכויות לתוכנת הפורומים שמורות © 2024 - 2000 לחברת Jelsoft Enterprises.
כל הזכויות שמורות ל Fresh.co.il ©

צור קשר | תקנון האתר