Skocz do zawartości
Zamknięcie Forum PC LAB

Szanowny Użytkowniku,

Informujemy, że za 30 dni tj. 30 listopada 2024 r. serwis internetowy Forum PC LAB zostanie zamknięty.

Administrator Serwisu Forum PC LAB - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie: wypowiada całość usług Serwisu Forum PC LAB z zachowaniem miesięcznego okresu wypowiedzenia.

Administrator Serwisu Forum PC LAB informuje, że:

  1. Z dniem 29 listopada 2024 r. zakończy się świadczenie wszystkich usług Serwisu Forum PC LAB. Ważną przyczyną uzasadniającą wypowiedzenie jest zamknięcie Serwisu Forum PC LAB
  2. Dotychczas zamowione przez Użytkownika usługi Serwisu Forum PC LAB będą świadczone w okresie wypowiedzenia tj. do dnia 29 listopada 2024 r.
  3. Po ogłoszeniu zamknięcia Serwisu Forum od dnia 30 października 2024 r. zakładanie nowych kont w serwisie Forum PC LAB nie będzie możliwe
  4. Wraz z zamknięciem Serwisu Forum PC LAB, tj. dnia 29 listopada 2024 r. nie będzie już dostępny katalog treści Forum PC LAB. Do tego czasu Użytkownicy Forum PC LAB mają dostęp do swoich treści w zakładce "Profil", gdzie mają możliwość ich skopiowania lub archiwizowania w formie screenshotów.
  5. Administrator danych osobowych Użytkowników - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie zapewnia realizację praw podmiotów danych osobowych przez cały okres świadczenia usług Serwisu Forum PC LAB. Szczegółowe informacje znajdziesz w Polityce Prywatności

Administrator informuje, iż wraz z zamknięciem Serwisu Forum PC LAB, dane osobowe Użytkowników Serwisu Forum PC LAB zostaną trwale usunięte ze względu na brak podstawy ich dalszego przetwarzania. Proces trwałego usuwania danych z kopii zapasowych może przekroczyć termin zamknięcia Forum PC LAB o kilka miesięcy. Wyjątek może stanowić przetwarzanie danych użytkownika do czasu zakończenia toczących się postepowań.

Temat został przeniesiony do archiwum

Ten temat przebywa obecnie w archiwum. Dodawanie nowych odpowiedzi zostało zablokowane.

gates22

[OPSS]Pisze, że źle, a działa ok

Rekomendowane odpowiedzi

Witam. Zrobiłem najprostsze zadanie z opss'a, jakie mogło być

Liczby Fibonacciego

 

Wszystko działa, a w systemie pisze, że błędna odpowiedź... Nie rozumiem czemu - może mi ktoś powiedzieć?

 

#include <iostream>

using namespace std;


int main()
{

int n, a;
cin >> n;

int *tab = new int[n];

for(int i = 0; i<n; i++)
{

	cin >> a;
	tab[i] = a;

}

//////////////

int wynik = 0;
int zmiennaA = 1;
int zmiennaB = 1;

////////////////////////


for(int j = 0; j<n; j++)
{
	for(int i = 0; i<tab[j]; i++)
	{

		wynik = wynik + zmiennaA;
		///////////////
		zmiennaA = zmiennaB;
		zmiennaB = wynik;

	}
	cout << wynik << endl;
	wynik = 0;
	zmiennaA = 1;
	zmiennaB = 1;

}

delete [] tab;
}

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

czy Fib(1000) zmiesci sie w int ?

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Pierwsza linijka wejścia zawiera dokładnie jedną liczbę całkowitą d, 1 ≤ d ≤ 1000, określającą liczbę zestawów danych. Każdy zestaw zajmuje jedną linijkę wejścia i zawiera dokładnie jedną liczbę naturalną n z przedziału [0..45].

 

To raczej nie to, zreszta gdy dałem int64_t też był błąd.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

dobra, nie doczytalem

 

0 tez jest brane pod uwage w tych testach ?

 

poza tym limit czasu wynosi 1s, a dla wiekszych wartosci n obliczenia moga troche potrwac

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

kurcze, nie doczytałem tak samo zadania :D n>1 miało być :D:D poprawiłem i zadziałało:

#include <iostream>

using namespace std;


int main()
{

int n;
cin >> n;
int a = 0;

int *tab = new int[n];

for(int i = 0; i<n; i++)
{

	cin >> a;
	if (a <=1 ) tab[i] = 1; else
	tab[i] = a;

}

//////////////

int wynik = 0;
int zmiennaA = 1;
int zmiennaB = 1;

////////////////////////


for(int j = 0; j<n; j++)
{
	for(int i = 0; i<tab[j]; i++)
	{

		wynik = wynik + zmiennaA;
		///////////////
		zmiennaA = zmiennaB;
		zmiennaB = wynik;

	}
	cout << wynik << endl;
	wynik = 0;
	zmiennaA = 1;
	zmiennaB = 1;

}

delete [] tab;
}

 

Można zamknąć.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Moja rada. W konkursach tego typu wyjście i wejście są niezależne, więc jeśli masz zadania w których wczytujesz w pierwszej linijce ilość zestawów danych, to nie zapamiętuj ich, bo to dodatkowy koszt. Możesz zrobić coś takiego:

wczytanie_ilosci_zestawow;
for(i=0; i<ilosc_danych; i++)
{
  wczytaj_zestaw;
  wykonaj_obliczenia;
  przekaz_do_wyjscia;
}

Tutaj masz przykład, moje rozwiązanie tego zadania (też lubię sobie coś zrobić na OPSS :P ):

#include <stdio.h>

int fib(int n){

int a=1, b=1, c=1;
int i;
for(i=3; i<n; i++){
 c=a+b;
 a=b;
 b=c;
}
return c;
}

int main(void){

int d, m, tab[1000];
short i;

scanf("%d", &d); 

for(i=0; i<d; i++){

scanf("%d", &m);
tab[i] = fib(m+2);

}

for(i=0; i<d; i++) printf("%d\n", tab[i]);
return 0;

}

Takie rozwiązanie nie powinno się liczyć dłużej niż 0.01 sekundy. :P

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

  • Ostatnio przeglądający   0 użytkowników

    Brak zarejestrowanych użytkowników przeglądających tę stronę.

×
×
  • Dodaj nową pozycję...