<?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=3398_-_Kps</id>
	<title>3398 - Kps - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=3398_-_Kps"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=3398_-_Kps&amp;action=history"/>
	<updated>2026-06-17T06:06:25Z</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=3398_-_Kps&amp;diff=8830&amp;oldid=prev</id>
		<title>Codrut Borcutean: Pagină nouă: Un cuvânt se numește &#039;&#039;&#039;k&#039;&#039;&#039;-ps dacă prefixul său de lungime &#039;&#039;&#039;k&#039;&#039;&#039; este identic cu sufixul de lungime &#039;&#039;&#039;k&#039;&#039;&#039;, iar &#039;&#039;&#039;k&#039;&#039;&#039; este cea mai mare valoare strict mai mică decât lungimea cuvântului, cu această proprietate. Dacă nu există nicio astfel de valoare &#039;&#039;&#039;k&#039;&#039;&#039; nenulă, spunem despre cuvânt că este &#039;&#039;&#039;0&#039;&#039;&#039;-ps. De exemplu, &#039;&#039;&#039;amalgam&#039;&#039;&#039; este &#039;&#039;&#039;2&#039;&#039;&#039;-ps, iar &#039;&#039;&#039;amestec&#039;&#039;&#039; este &#039;&#039;&#039;0&#039;&#039;&#039;-ps.  == Cerinţa == Rezolvați următoarele cerințe:  1) Se dă un cuvânt. De...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=3398_-_Kps&amp;diff=8830&amp;oldid=prev"/>
		<updated>2024-01-03T10:59:39Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: Un cuvânt se numește &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039;-ps dacă prefixul său de lungime &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; este identic cu sufixul de lungime &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039;, iar &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; este cea mai mare valoare strict mai mică decât lungimea cuvântului, cu această proprietate. Dacă nu există nicio astfel de valoare &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; nenulă, spunem despre cuvânt că este &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;-ps. De exemplu, &amp;#039;&amp;#039;&amp;#039;amalgam&amp;#039;&amp;#039;&amp;#039; este &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039;-ps, iar &amp;#039;&amp;#039;&amp;#039;amestec&amp;#039;&amp;#039;&amp;#039; este &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;-ps.  == Cerinţa == Rezolvați următoarele cerințe:  1) Se dă un cuvânt. De...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Un cuvânt se numește &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039;-ps dacă prefixul său de lungime &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; este identic cu sufixul de lungime &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039;, iar &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; este cea mai mare valoare strict mai mică decât lungimea cuvântului, cu această proprietate. Dacă nu există nicio astfel de valoare &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; nenulă, spunem despre cuvânt că este &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;-ps. De exemplu, &amp;#039;&amp;#039;&amp;#039;amalgam&amp;#039;&amp;#039;&amp;#039; este &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039;-ps, iar &amp;#039;&amp;#039;&amp;#039;amestec&amp;#039;&amp;#039;&amp;#039; este &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;-ps.&lt;br /&gt;
&lt;br /&gt;
== Cerinţa ==&lt;br /&gt;
Rezolvați următoarele cerințe:&lt;br /&gt;
&lt;br /&gt;
1) Se dă un cuvânt. Determinați &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; asfel încât cuvântul să fie &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039;-ps.&lt;br /&gt;
&lt;br /&gt;
2) Se dă un șir de caractere în care cuvintele sunt alcătuite din litere mici ale alfabetului englez și sunt separate prin spații. Să se afișeze în ordine cuvintele &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;-ps, &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039;-ps, &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039;-ps, &amp;#039;&amp;#039;&amp;#039;3&amp;#039;&amp;#039;&amp;#039;-ps, etc, până la cel mai mare &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039; pentru care există în șir cel puțin un cuvânt &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039;-ps. Pentru fiecare categorie, cuvintele vor fi afișate în ordine alfabetică.&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
 Fișierul de intrare &amp;#039;&amp;#039;&amp;#039;kpsin.txt&amp;#039;&amp;#039;&amp;#039; conține pe prima linie numărul &amp;#039;&amp;#039;&amp;#039;C&amp;#039;&amp;#039;&amp;#039;, care reprezintă cerința și poate fi &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039; sau &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
* Dacă &amp;#039;&amp;#039;&amp;#039;C=1&amp;#039;&amp;#039;&amp;#039;, a doua linie conține un cuvânt format litere mici ale alfabetului englez.&lt;br /&gt;
* daca &amp;#039;&amp;#039;&amp;#039;C=2&amp;#039;&amp;#039;&amp;#039;, a doua linie conține șir de caractere în care cuvintele sunt alcătuite din litere mici ale alfabetului englez și sunt separate prin spații.&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
* Dacă &amp;#039;&amp;#039;&amp;#039;C=1&amp;#039;&amp;#039;&amp;#039;, fișierul de ieșire &amp;#039;&amp;#039;&amp;#039;kpsout.txt&amp;#039;&amp;#039;&amp;#039; va conține pe prima linie numărul &amp;#039;&amp;#039;&amp;#039;K&amp;#039;&amp;#039;&amp;#039;, astel încât cuvântul dat este cuvânt &amp;#039;&amp;#039;&amp;#039;K&amp;#039;&amp;#039;&amp;#039;-ps. Dacă cuvântul dat nu este cuvânt &amp;#039;&amp;#039;&amp;#039;k&amp;#039;&amp;#039;&amp;#039;-ps, se va afișa valoarea &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Dacă &amp;#039;&amp;#039;&amp;#039;C=2&amp;#039;&amp;#039;&amp;#039;, fișierul de ieșire &amp;#039;&amp;#039;&amp;#039;kpsout.txt&amp;#039;&amp;#039;&amp;#039; va conține mai multe linii:&lt;br /&gt;
* prima linie corespunde cuvintelor &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;-ps, a doua corespunde cuvintelor &amp;#039;&amp;#039;&amp;#039;1&amp;#039;&amp;#039;&amp;#039;-ps, a treia cuvintelor &amp;#039;&amp;#039;&amp;#039;2&amp;#039;&amp;#039;&amp;#039;-ps, etc.&lt;br /&gt;
* fiecare linie începe cu numărul de cuvinte din categoria curentă, urmat de un spațiu și de aceste cuvinte, in ordine alfabetică, separate prin câte un spațiu;&lt;br /&gt;
* dacă nu există niciun cuvânt dintr-o anumită categorie, linia corespunzătoare va conține doar valoarea &amp;#039;&amp;#039;&amp;#039;0&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
== Restricţii şi precizări ==&lt;br /&gt;
* pentru &amp;#039;&amp;#039;&amp;#039;C=1&amp;#039;&amp;#039;&amp;#039;, cuvântul dat va avea cel mult &amp;#039;&amp;#039;&amp;#039;1000&amp;#039;&amp;#039;&amp;#039; de litere;&lt;br /&gt;
* pentru &amp;#039;&amp;#039;&amp;#039;C=2&amp;#039;&amp;#039;&amp;#039;, șirul dat va avea cel mult &amp;#039;&amp;#039;&amp;#039;10000&amp;#039;&amp;#039;&amp;#039; de caractere, fiecare cuvânt având cel mult &amp;#039;&amp;#039;&amp;#039;100&amp;#039;&amp;#039;&amp;#039; de litere;&lt;br /&gt;
* pentru 50 de puncte, &amp;#039;&amp;#039;&amp;#039;C=1&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
== Exemplu 1 ==&lt;br /&gt;
; kpsin.txt&lt;br /&gt;
 1&lt;br /&gt;
 amalgam&lt;br /&gt;
; kpsout.txt&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse&lt;br /&gt;
 2&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
== Exemplu 2 ==&lt;br /&gt;
; kpsin.txt&lt;br /&gt;
 2&lt;br /&gt;
 asdfqwasdf zar amalgam  zarzar  barbar ghjtttyuttghj asaswasas kps&lt;br /&gt;
; kpsout.txt&lt;br /&gt;
 Datele de intrare corespund restrictiilor impuse&lt;br /&gt;
 2 kps zar&lt;br /&gt;
 0&lt;br /&gt;
 1 amalgam&lt;br /&gt;
 3 barbar ghjtttyuttghj zarzar&lt;br /&gt;
 2 asaswasas asdfqwasdf&lt;br /&gt;
== Exemplu 3 ==&lt;br /&gt;
; kpsin.txt&lt;br /&gt;
 1&lt;br /&gt;
 ASD SCCS&lt;br /&gt;
; kpsout.txt&lt;br /&gt;
 Datele de intrare nu corespund restrictiilor 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;
def k_ps(cuvant):&lt;br /&gt;
    # Determină k pentru care cuvântul este k-ps&lt;br /&gt;
    for k in range(len(cuvant) - 1, 0, -1):&lt;br /&gt;
        if cuvant[:k] == cuvant[-k:]:&lt;br /&gt;
            return k&lt;br /&gt;
    return 0&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def sortare_cuvinte(sir):&lt;br /&gt;
    # Sortează cuvintele în funcție de valoarea k&lt;br /&gt;
    cuvinte = sir.split()&lt;br /&gt;
    k_cuvinte = {k: [] for k in range(max(map(k_ps, cuvinte)) + 1)}&lt;br /&gt;
    for cuvant in cuvinte:&lt;br /&gt;
        k_cuvinte[k_ps(cuvant)].append(cuvant)&lt;br /&gt;
    for k in k_cuvinte:&lt;br /&gt;
        k_cuvinte[k].sort()&lt;br /&gt;
    return k_cuvinte&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    with open(&amp;#039;kpsin.txt&amp;#039;, &amp;#039;r&amp;#039;) as fin, open(&amp;#039;kpsout.txt&amp;#039;, &amp;#039;w&amp;#039;) as fout:&lt;br /&gt;
        c = int(fin.readline().strip())&lt;br /&gt;
&lt;br /&gt;
        # Verifică dacă datele de intrare respectă restricțiile&lt;br /&gt;
        if c == 1:&lt;br /&gt;
            cuvant = fin.readline().strip()&lt;br /&gt;
            if len(cuvant) &amp;gt; 1000 or not cuvant.islower():&lt;br /&gt;
                fout.write(&amp;quot;Datele de intrare nu corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
                return&lt;br /&gt;
            fout.write(&amp;quot;Datele de intrare corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
            fout.write(str(k_ps(cuvant)) + &amp;#039;\n&amp;#039;)&lt;br /&gt;
        elif c == 2:&lt;br /&gt;
            sir = fin.readline().strip()&lt;br /&gt;
            if len(sir) &amp;gt; 10000 or not all(cuvant.islower() for cuvant in sir.split()):&lt;br /&gt;
                fout.write(&amp;quot;Datele de intrare nu corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
                return&lt;br /&gt;
            fout.write(&amp;quot;Datele de intrare corespund restrictiilor impuse\n&amp;quot;)&lt;br /&gt;
            k_cuvinte = sortare_cuvinte(sir)&lt;br /&gt;
            for k in k_cuvinte:&lt;br /&gt;
                fout.write(str(len(k_cuvinte[k])) + &amp;#039; &amp;#039; + &amp;#039; &amp;#039;.join(k_cuvinte[k]) + &amp;#039;\n&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;quot;__main__&amp;quot;:&lt;br /&gt;
    main()&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Codrut Borcutean</name></author>
	</entry>
</feed>