<?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=2449_-_PM</id>
	<title>2449 - PM - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=2449_-_PM"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2449_-_PM&amp;action=history"/>
	<updated>2026-05-01T15:32:23Z</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=2449_-_PM&amp;diff=9740&amp;oldid=prev</id>
		<title>Cristina94: Pagină nouă: ==Enunţ== Vom numi secvenţă PM o succesiune formată din plus şi minus, care NU conţine două semne minus alăturate. De exemplu, există 5 secvenţe PM de lungime 3: + + + , + + - , + - + , - + + , - + -.  ==Cerința== Să se determine numărul de secvenţe PM care conţin x semne plus şi y semne minus.  ==Date de intrare== Fişierul de intrare pm.in conţine pe prima linie două numere naturale separate prin spaţiu x, y, cu semnificaţia din enunţ.  ==Date de ieșir...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2449_-_PM&amp;diff=9740&amp;oldid=prev"/>
		<updated>2024-04-01T04:29:36Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: ==Enunţ== Vom numi secvenţă PM o succesiune formată din plus şi minus, care NU conţine două semne minus alăturate. De exemplu, există 5 secvenţe PM de lungime 3: + + + , + + - , + - + , - + + , - + -.  ==Cerința== Să se determine numărul de secvenţe PM care conţin x semne plus şi y semne minus.  ==Date de intrare== Fişierul de intrare pm.in conţine pe prima linie două numere naturale separate prin spaţiu x, y, cu semnificaţia din enunţ.  ==Date de ieșir...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Enunţ==&lt;br /&gt;
Vom numi secvenţă PM o succesiune formată din plus şi minus, care NU conţine două semne minus alăturate.&lt;br /&gt;
De exemplu, există 5 secvenţe PM de lungime 3: + + + , + + - , + - + , - + + , - + -.&lt;br /&gt;
&lt;br /&gt;
==Cerința==&lt;br /&gt;
Să se determine numărul de secvenţe PM care conţin x semne plus şi y semne minus.&lt;br /&gt;
&lt;br /&gt;
==Date de intrare==&lt;br /&gt;
Fişierul de intrare pm.in conţine pe prima linie două numere naturale separate prin spaţiu x, y, cu semnificaţia din enunţ.&lt;br /&gt;
&lt;br /&gt;
==Date de ieșire==&lt;br /&gt;
Fişierul de ieşire pm.out va conţine o singură linie pe care va fi scris un singur număr natural, reprezentând numărul de secvenţe PM care conţin x semne plus şi y semne minus.&lt;br /&gt;
&lt;br /&gt;
==Restricții și precizări==&lt;br /&gt;
*0 ≤ y ≤ x ≤ 250&lt;br /&gt;
*Rezultatul va avea maxim 100 cifre.&lt;br /&gt;
*Pentru 50% din testele de evaluare, x &amp;lt; 32.&lt;br /&gt;
*10% din punctaj se va acorda pe exemple.&lt;br /&gt;
&lt;br /&gt;
==Exemplu 1==&lt;br /&gt;
;pm.in&lt;br /&gt;
:2 1&lt;br /&gt;
&lt;br /&gt;
;pm.out&lt;br /&gt;
:3&lt;br /&gt;
&lt;br /&gt;
==Exemplu 2==&lt;br /&gt;
;pm.in&lt;br /&gt;
:300 200&lt;br /&gt;
&lt;br /&gt;
;pm.out&lt;br /&gt;
:Date de intrare invalide.&lt;br /&gt;
&lt;br /&gt;
==Rezolvare==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;python&amp;quot; line&amp;gt;&lt;br /&gt;
#2449 PM&lt;br /&gt;
def verificare_date_intrare(x, y):&lt;br /&gt;
  if not (0 &amp;lt;= y &amp;lt;= x &amp;lt;= 250):&lt;br /&gt;
    return False&lt;br /&gt;
  return True&lt;br /&gt;
&lt;br /&gt;
def numar_secvente_PM(x, y):&lt;br /&gt;
  if not verificare_date_intrare(x, y):&lt;br /&gt;
    return &amp;quot;Date de intrare invalide.&amp;quot;&lt;br /&gt;
  &lt;br /&gt;
  dp = [[0] * (y + 1) for _ in range(x + 1)]&lt;br /&gt;
  dp[0][0] = 1&lt;br /&gt;
&lt;br /&gt;
  for i in range(1, x + 1):&lt;br /&gt;
    for j in range(min(i, y) + 1):&lt;br /&gt;
      if j == 0:&lt;br /&gt;
        dp[i][j] = dp[i - 1][j]&lt;br /&gt;
      else:&lt;br /&gt;
        dp[i][j] = dp[i - 1][j] + dp[i - 1][j - 1]&lt;br /&gt;
&lt;br /&gt;
  numar_total = sum(dp[x])&lt;br /&gt;
&lt;br /&gt;
  return numar_total&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
  with open(&amp;quot;pm.in&amp;quot;, &amp;quot;r&amp;quot;) as fin:&lt;br /&gt;
    x, y = map(int, fin.readline().split())&lt;br /&gt;
&lt;br /&gt;
  rezultat = numar_secvente_PM(x, y)&lt;br /&gt;
&lt;br /&gt;
  with open(&amp;quot;pm.out&amp;quot;, &amp;quot;w&amp;quot;) as fout:&lt;br /&gt;
    fout.write(str(rezultat) + &amp;quot;\n&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    main()&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Cristina94</name></author>
	</entry>
</feed>