Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Помощ за една функция на C++

Featured Replies

Здравейте имам нужда от малко помощ за една функция, която трябва да намери най-малките елементи в стекове, кратни на число въведено от клавиатурата, но неповтарящи се в двете структури(двата стека не могат да имат еднакъв най-малък елемент).Пробвах се да направя функцията чрез записване на всички кратни елементи(от съответния стек) в масив(подредени възходящо) и след това сравнявам най-малките елементи от масивите и ако те са еднакви, то извеждам следващите най-малки неповтарящи се елементи.

void findelem(elem* S,int ch, int arr[]){
	int temp, br=0;
	while(S){
		if(ch%S->key==0){ //namirane na kratni na vavedenoto chislo
			arr[br]=S->key; //zapisvane na kratnite v masiv
			br++;
		}
		S = S->next;
	}
		for(int i=0; i<br; i++) //sortirane na masiva vazhodqshto
                for(int j=i+1; j<br; j++)
                        if(arr[i]>arr[j])
                            {
                                temp=arr[i];
                                arr[i]=arr[j];
                                arr[j]=temp;
                            }
}

void findit(){
	int ch, i=0;
	cout<<"Input integer: ";
	cin>>ch; //vavejdane na chislo
	findelem(P,ch,arr1);
	findelem(N,ch,arr2);
	while(arr1[i]==arr2[i]) //ako nai-malkite elementi sa ednakvi se preminava na sledvashtite nai-malki
		i++;
	cout<<"Smallest elem from stack 1: "<<arr1[i]<<endl;
	cout<<"Smallest elem from stack 2: "<<arr2[i]<<endl;
}

Ще съм много благодарен, ако някой може да погледне кода и да ми помогне.

void findelem(elem *S, int &L1, int &L2, int d)
{
    L1 = INT_MAX;
    while (S) 
    {
        if ((S->key % d == 0) && (S->key < L1))
        {
            L2 = L1;
            L1 = S->key;
        }
        S = S->next;
    }
}

void findit(elem *S, elem *Q, int d)
{
     int s1, s2, q1, q2;
     findelem(S, s1, s2, d);
     findelem(Q, q1, q2, d);
     
     /*  ***  */
  
     if(s1==q1)
     {
         if (s2<q2) s1=s2;
         else q1=q2;
     }
     
     if (s1==INT_MAX || q1==INT_MAX) cout<<"NO solution\n";
     else cout<<"Stack #1 = "<<s1<<", Stack #2 = "<<q1<<endl;
}

В случай че искаш да се изведе резултат и ако само единия стек има определен мимимум

трябва да се добавят още две проверки след изпълнението на findelem()  където е коментара

     if (s1==INT_MAX && q1!=INT_MAX)
     {
         cout<<"Stack #1 No solution, Stack #2 = "<<q1<<endl;
         return;
     }
     
     if (s1!=INT_MAX && q1==INT_MAX)
     {
         cout<<"Stack #1 = "<<s1<<", Stack #2 No solution\n";
         return;
     }

 

Редактирано от ined (преглед на промените)

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    26%
    Дарени 256.00 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.