Member 13481527 Ответов: 3

Во время выполнения результирующего цикла не нарушается оператор


#include<stdio.h>
int a[100],c,n,search;
void L_search(int);
void B_search(int);
int main()
{
	int ch;
	printf("Enter the number of element:");
	scanf("%d",&n);
	printf("Enter %d elements:\t",n);
	for(c=0;c<n;c++)
	{
	  scanf("%d",&a[c]);
	}
	printf("Enter that element to search>>");
	scanf("%d",&search);
	printf("way to search an element...");
	printf("\n1.Linear search\n2.Binary search\n");
	printf("choose any...>>");
	scanf("%d",&ch);
	while(ch)
	{
		switch(ch)
		{
			case 1:
				printf("Searching in Linear way...\n");
				L_search(search);
				break;
			case 2:
				printf("Searching in binary way...\n");
				B_search(search);
				break;
			default :
				printf("Invalid option.\nPlease try again");
		}
	}
	return 0;
}
void L_search(int)
{
	 for(c=0;c<=n;c++)
   {
      if (a[c]==search)  
      {
         printf("%d is present at location %d.\n", search, c+1);
         break;
      }
      else
      printf("Number Not Found");
   }
   
}
void B_search(int)
{
	int first = 0;
	int last = n-1;
	int middle = (first+last)/2;
	while (first <= last)
	{
		if(a[middle] < search)
		{
			first = middle + 1;

		}
		else if(a[middle] == search)
		{
			printf("%d found at location %d\n", search, middle+1);
			break;
		}
		else
		{
			 last = middle - 1;
		}
		middle = (first + last)/2;
	}
	if(first > last)
	{
		printf("Not found! %d is not present in the list.",search);
	}
}


Что я уже пробовал:

я попытался запустить... программа работает успешно, но после ввода значения во время выполнения результата ... результирующий цикл не нарушает своего оператора...

3 Ответов

Рейтинг:
28

OriginalGriff

Описание вашей проблемы очень расплывчато и мало что объясняет.
Но...как только вы войдете в петлю внутри main, у вас нет возможности выйти или изменить параметры. Переместите входной код выбора внутри цикла и добавьте опцию "выход" в список.


Рейтинг:
10

CPallini

У вас есть серьезный недостаток в вашей основной функции, попробуйте вместо этого следующий код.

int main()
{
  int ch;
  printf("Enter the number of element:");
  scanf("%d",&n);
  printf("Enter %d elements:\t",n);
  for(c=0;c<n;c++)
  {
    scanf("%d",&a[c]);
  }

  do
  {
    printf("Enter that element to search>>");
    scanf("%d",&search);
    printf("way to search an element...");
    printf("\n1.Linear search\n2.Binary search\n");
    printf("choose any...>>");
    scanf("%d",&ch);
    switch(ch)
    {
    case 1:
      printf("Searching in Linear way...\n");
      L_search(search);
      break;
    case 2:
      printf("Searching in binary way...\n");
      B_search(search);
      break;
    case -1:
      printf("goodbye.\n");
      break;
    default :
      printf("Invalid option.\nPlease try again\n");
      break;
    }
  } while ( ch != -1);
  return 0;
}

Кроме того, у вас есть небольшой недостаток в вашем L_search функция, измененная на (вы также должны изменить ее прототип):
void L_search()
{
   for(c=0;c<=n;c++)
   {
      if (a[c]==search)
      {
         printf("%d is present at location %d.\n", search, c+1);
         return;
      }
   }
   printf("Number Not Found\n");
}


Я не анализировал ситуацию. B_search функция, это оставлено вам как упражнение.

Обратите внимание: использование глобальных переменных-плохая практика, я настоятельно рекомендую вам использовать локальные переменные и передавать их в качестве параметров функции.


Рейтинг:
1

Patrice T

Цитата:
я попытался запустить... программа работает успешно, но после ввода значения во время выполнения результата ... результирующий цикл не нарушает своего оператора...

Совсем не ясно.
Когда вы не понимаете, что делает ваш код, решение - это отладчик.

Существует инструмент, который позволяет вам видеть, что делает ваш код, его имя отладчик Это также отличный инструмент обучения, потому что он показывает вам реальность, и вы можете увидеть, какие ожидания соответствуют реальности.
Когда вы не понимаете, что делает ваш код или почему он делает то, что он делает, ответ таков: отладчик.
Используйте отладчик, чтобы увидеть, что делает ваш код. Просто установите точку останова и посмотрите, как работает ваш код, отладчик позволит вам выполнять строки 1 на 1 и проверять переменные по мере их выполнения.

Отладчик - Википедия, свободная энциклопедия[^]

Освоение отладки в Visual Studio 2010 - руководство для начинающих[^]
Базовая отладка с помощью Visual Studio 2010 - YouTube[^]
Отладчик здесь, чтобы показать вам, что делает ваш код, и ваша задача-сравнить с тем, что он должен делать.
В отладчике нет никакой магии, он не находит ошибок, он просто помогает вам. Когда код не делает того, что ожидается, вы близки к ошибке.