Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2017-08-31 18:07:34

  hubot - Użytkownik

hubot
Użytkownik
Zarejestrowany: 2017-04-13

[C] Obliczanie wynagrodzenia

Mam problem z następującym zadaniem, konkretnie podpunktem c:

Napisz program, który pobiera liczbę przepracowanych godzin w tygodniu, a następnie wyświetla wynagrodzenie brutto, podatek oraz wynagrodzenie netto. Przyjmij następujące wartości:

a) podstawowe wynagrodzenie = 40zł/godzinę
b) nadgodziny (powyżej 40 godzin w tygodniu) = 150% podstawowego wynagrodzenia
c) podatek 15% dla pierwszych 1200 zł
20% dla kolejnych 600 zł
25% dla reszty wynagrodzenia

Użyj stałych #define i nie przejmuj się, że przykład nie przystaje do aktualnych przepisów podatkowych.[/quote]
Mój kod:

Kod:

#include <stdio.h>
#define BASIC_SALARY 40.0f
#define OVERTIME 40

int main(void) {
    int workedHours;
    printf("Podaj liczbe przepracowanych godzin w tygodniu: ");
    scanf("%i", workedHours);
    float netSalary, glossSalary, tax;
    float ;
    if (workedHours <= OVERTIME) {
        netSalary = BASIC_SALARY * workedHours;
    } else {
        netSalary *= 1.5f;
    }
    // jak obliczyć podatek?
    //printf("Wynagrodzenie brutto: %i\n", )

    return 0;
}

Nie potrafię sobie poradzić z obliczeniem podatku. Proszę o przedstawienie sposobu jak mógłbym to opakować w jakieś if-y.

Mam nadzieję że ktoś mi pomoże.

Ostatnio edytowany przez hubot (2017-08-31 18:09:11)

Offline

 

#2  2017-08-31 18:23:25

  arecki - Użytkownik

arecki
Użytkownik
Skąd: 44 Bronson Lane Hensonville
Zarejestrowany: 2016-03-03

Re: [C] Obliczanie wynagrodzenia

[quote=hubot]Mam problem z następującym zadaniem, konkretnie podpunktem c:

Napisz program, który pobiera liczbę przepracowanych godzin w tygodniu, a następnie wyświetla wynagrodzenie brutto, podatek oraz wynagrodzenie netto. Przyjmij następujące wartości:

a) podstawowe wynagrodzenie = 40zł/godzinę
b) nadgodziny (powyżej 40 godzin w tygodniu) = 150% podstawowego wynagrodzenia
c) podatek 15% dla pierwszych 1200 zł
20% dla kolejnych 600 zł
25% dla reszty wynagrodzenia

Użyj stałych #define i nie przejmuj się, że przykład nie przystaje do aktualnych przepisów podatkowych.[/quote]
Mój kod:

Kod:

#include <stdio.h>
#define BASIC_SALARY 40.0f
#define OVERTIME 40

int main(void) {
    int workedHours;
    printf("Podaj liczbe przepracowanych godzin w tygodniu: ");
    scanf("%i", workedHours);
    float netSalary, glossSalary, tax;
    float ;
    if (workedHours <= OVERTIME) {
        netSalary = BASIC_SALARY * workedHours;
    } else {
        netSalary *= 1.5f;
    }
    // jak obliczyć podatek?
    //printf("Wynagrodzenie brutto: %i\n", )

    return 0;
}

Nie potrafię sobie poradzić z obliczeniem podatku. Proszę o przedstawienie sposobu jak mógłbym to opakować w jakieś if-y.

Mam nadzieję że ktoś mi pomoże.[/quote]
Przecież to czysta matematyka:
Jeżeli wynagrodzenie mniejsze/równe 1200 wtedy licz podatek 15% z kwoty = wynagrodzenie
Jeżeli wynagrodzenie w przedziale prawostronnie domkniętym 1200 - 1800 wtedy licz podatek 15% z kwoty1200 i 20% z kwoty = wynagrodzenie - 1200
Jeżeli wynagrodzenie większe od 1800 wtedy licz podatek 15% z kwoty 1200 i 20% z kwoty 600 oraz 25% z kwoty = wynagrodzenie - 1800

Ostatnio edytowany przez arecki (2017-08-31 18:33:54)

Offline

 

#3  2017-08-31 22:41:18

  mati75 - Psuj

mati75
Psuj
Skąd: default city
Zarejestrowany: 2010-03-14
Serwis

Re: [C] Obliczanie wynagrodzenia

Narysuj sobie do tego podatku algorytm w postaci schematu blokowego. Będzie łatwiej zrozumieć.


[img]https://l0calh0st.pl/obrazki/userbar.png[/img]

Offline

 

#4  2017-09-03 14:55:59

  jezoo - Dzięcioł

jezoo
Dzięcioł
Skąd: Z lasu
Zarejestrowany: 2005-09-02

Re: [C] Obliczanie wynagrodzenia

Jeżeli chcesz obliczyć z kwoty brutto kwotę netto to np. kwota brutto to 1200zł, czyli:

Kod:

float price = 1200, tax = 1.34; // Według księgowych tyle jest odliczane od naszej wypłaty: emerytalnr, zdrowotne, fśp

float salary = price/tax
float tribute = price-salary;

ot tak na szybko. Po drugie można również znaleźć w jaki sposób można to obliczyć: http://www.vat.pl/obliczanie-wynagrodzenia-netto-praca-i-zlecenie-u-jednego-pracodawcy-10236/


[img]http://intershock.pl/images/icons/freebsd.jpg[/img] [img]http://www.the-eleven.com/site_media/static/img/postgresql_powered.png[/img] [img]http://www.wwgmc.com/images/badge_php.gif[/img]
LRU #480459

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
Możesz wyłączyć AdBlock — tu nie ma reklam ;-)

[ Generated in 0.033 seconds, 10 queries executed ]

Informacje debugowania

Time (s) Query
0.00015 SET CHARSET latin2
0.00007 SET NAMES latin2
0.00080 SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='3.235.181.103' WHERE u.id=1
0.00783 UPDATE punbb_online SET logged=1594102263 WHERE ident='3.235.181.103'
0.00042 SELECT * FROM punbb_online WHERE logged<1594101963
0.01022 DELETE FROM punbb_online WHERE ident='54.36.148.1'
0.00065 SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=29874 AND t.moved_to IS NULL
0.00008 SELECT search_for, replace_with FROM punbb_censoring
0.00118 SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=29874 ORDER BY p.id LIMIT 0,25
0.00815 UPDATE punbb_topics SET num_views=num_views+1 WHERE id=29874
Total query time: 0.02955 s