<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0721_-_CD</id>
	<title>0721 - CD - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=0721_-_CD"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0721_-_CD&amp;action=history"/>
	<updated>2026-05-01T10:56:44Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://wiki.universitas.ro/index.php?title=0721_-_CD&amp;diff=8728&amp;oldid=prev</id>
		<title>Ramona Dragoș: Pagină nouă: == Enunt == Ionică a strâns foarte multe CD-uri cu jocuri, muzică, filme, etc. pe care le are aşezate în n cutii, codificate prin 1, 2, …, n. Pe la Ionică vine în vizită vărul lui, Florin, care tocmai câştigase un concurs de matematică. Ca să-i mai taie din elan, Ionică îi propune lui Florin să pună o parte din CD-uri într-o ladă mai mare, astfel încât să se ia din fiecare cutie cel puţin câte un CD şi la sfârşit să rămână în fiecare cutie ce...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=0721_-_CD&amp;diff=8728&amp;oldid=prev"/>
		<updated>2023-12-31T13:41:54Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunt == Ionică a strâns foarte multe CD-uri cu jocuri, muzică, filme, etc. pe care le are aşezate în n cutii, codificate prin 1, 2, …, n. Pe la Ionică vine în vizită vărul lui, Florin, care tocmai câştigase un concurs de matematică. Ca să-i mai taie din elan, Ionică îi propune lui Florin să pună o parte din CD-uri într-o ladă mai mare, astfel încât să se ia din fiecare cutie cel puţin câte un CD şi la sfârşit să rămână în fiecare cutie ce...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunt ==&lt;br /&gt;
Ionică a strâns foarte multe CD-uri cu jocuri, muzică, filme, etc. pe care le are aşezate în n cutii, codificate prin 1, 2, …, n. Pe la Ionică vine în vizită vărul lui, Florin, care tocmai câştigase un concurs de matematică. Ca să-i mai taie din elan, Ionică îi propune lui Florin să pună o parte din CD-uri într-o ladă mai mare, astfel încât să se ia din fiecare cutie cel puţin câte un CD şi la sfârşit să rămână în fiecare cutie cel puţin un CD.&lt;br /&gt;
&lt;br /&gt;
Pentru a complica problema, Ionică nu îi spune lui Florin câte CD-uri sunt în fiecare cutie, ci îi spune că are în total S CD-uri şi că, dacă ia din fiecare cutie un număr de CD-uri şi le pune în altă cutie va obţine în final acelaşi număr de CD-uri în toate cutiile.&lt;br /&gt;
== Cerința ==&lt;br /&gt;
Să se scrie un program care cunoscând n, S şi numărul de CD-uri mutate din fiecare cutie, determină numărul k de modalităţi distincte de introducere a CD-urilor în ladă, respectând regula din enunţ.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul de intrare cdin.txt conține pe prima linie numerele naturale n şi S separate printr-un spaţiu, iar pe următoarele n linii perechile de numere naturale y[i] c[i] separate printr-un spaţiu, corespunzătoare numărului de CD-uri y[i] , care se pun din cutia i în cutia c[i] , i=1,2,...,n.&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fișierul de ieșire cdout.txt va conține pe prima linie numărul k modulo 9901.&lt;br /&gt;
== Restricții și precizări ==&lt;br /&gt;
*2 &amp;amp;les; n &amp;amp;les; 300&lt;br /&gt;
*În fiecare cutie sunt cel mult 1000 CD-uri.&lt;br /&gt;
*k modulo p reprezintă restul împărţirii lui k la p&lt;br /&gt;
*S modulo n = 0&lt;br /&gt;
*O modalitate de alegere a CD-urilor ce vor fi puse în ladă diferă de o altă modalitate, dacă din cel puţin o cutie se alege un număr diferit de CD-uri.&lt;br /&gt;
== Exemplu 1 ==&lt;br /&gt;
;cdin.txt&lt;br /&gt;
:3 12&lt;br /&gt;
:3 2&lt;br /&gt;
:2 3&lt;br /&gt;
:1 1&lt;br /&gt;
;cd.out&lt;br /&gt;
:20&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Exemplu 2 ==&lt;br /&gt;
;cdin.txt&lt;br /&gt;
:0 -1&lt;br /&gt;
;cdout.txt&lt;br /&gt;
: Nu au fost respectate cerintele impuse&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Rezolvare ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
#0721 - CD&lt;br /&gt;
def read_input(file_name):&lt;br /&gt;
    try:&lt;br /&gt;
        with open(file_name, &amp;#039;r&amp;#039;) as file:&lt;br /&gt;
            n, S = map(int, file.readline().split())&lt;br /&gt;
            data = [tuple(map(int, line.split())) for line in file.readlines()]&lt;br /&gt;
&lt;br /&gt;
            if not (2 &amp;lt;= n &amp;lt;= 300 and S % n == 0 and all(0 &amp;lt;= y &amp;lt;= 1000 and 1 &amp;lt;= c &amp;lt;= n for y, c in data)):&lt;br /&gt;
                raise ValueError(&amp;quot;Numerele nu respecta restricțiile.&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
            return n, S, data&lt;br /&gt;
    except Exception as e:&lt;br /&gt;
        print(f&amp;quot;Nu au fost respectate cerintele impuse: {str(e)}&amp;quot;)&lt;br /&gt;
        return None&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def write_output(file_name, result):&lt;br /&gt;
    with open(file_name, &amp;#039;w&amp;#039;) as file:&lt;br /&gt;
        if result is not None:&lt;br /&gt;
            file.write(f&amp;quot;{result}\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def count_ways(n, S, data):&lt;br /&gt;
    mod = 9901&lt;br /&gt;
    dp = [0] * (S + 1)&lt;br /&gt;
    dp[0] = 1&lt;br /&gt;
&lt;br /&gt;
    for y, c in data:&lt;br /&gt;
        for i in range(S, y - 1, -1):&lt;br /&gt;
            dp[i] = (dp[i] + dp[i - y] - dp[i - y - 1] + mod) % mod&lt;br /&gt;
&lt;br /&gt;
    return dp[S]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def main(input_file, output_file):&lt;br /&gt;
    result = read_input(input_file)&lt;br /&gt;
    if result is not None:&lt;br /&gt;
        n, S, data = result&lt;br /&gt;
        result = count_ways(n, S, data)&lt;br /&gt;
        write_output(output_file, result)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    main(&amp;quot;cdin.txt&amp;quot;, &amp;quot;cdout.txt&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Ramona Dragoș</name></author>
	</entry>
</feed>