<?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=2654_-_Sort_All</id>
	<title>2654 - Sort All - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.universitas.ro/index.php?action=history&amp;feed=atom&amp;title=2654_-_Sort_All"/>
	<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2654_-_Sort_All&amp;action=history"/>
	<updated>2026-05-01T06:31:47Z</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=2654_-_Sort_All&amp;diff=10034&amp;oldid=prev</id>
		<title>RebecaBud: Pagină nouă: == Enunt ==  Pentru un șir de numere A  se definește următoarea funcție de cost: f(A)=1⋅v1+2⋅v2+…+k⋅vk , unde [v1,v2,…,vk]  sunt valorile distincte ale lui A , ordonate crescător. == Cerinţa == Fiind dat un șir de N numere naturale A, să se calculeze suma aplicării funcției f pe toate subsecvențele lui A (i.e. suma după (1 ≤ i ≤ j ≤ N) din f(A[i...j]), unde A[i…j] este subsecvența de la i la j). == Date de intrare == Fișierul sortall.in conțin...</title>
		<link rel="alternate" type="text/html" href="https://wiki.universitas.ro/index.php?title=2654_-_Sort_All&amp;diff=10034&amp;oldid=prev"/>
		<updated>2024-06-03T17:16:37Z</updated>

		<summary type="html">&lt;p&gt;Pagină nouă: == Enunt ==  Pentru un șir de numere A  se definește următoarea funcție de cost: f(A)=1⋅v1+2⋅v2+…+k⋅vk , unde [v1,v2,…,vk]  sunt valorile distincte ale lui A , ordonate crescător. == Cerinţa == Fiind dat un șir de N numere naturale A, să se calculeze suma aplicării funcției f pe toate subsecvențele lui A (i.e. suma după (1 ≤ i ≤ j ≤ N) din f(A[i...j]), unde A[i…j] este subsecvența de la i la j). == Date de intrare == Fișierul sortall.in conțin...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Enunt == &lt;br /&gt;
Pentru un șir de numere A&lt;br /&gt;
 se definește următoarea funcție de cost: f(A)=1⋅v1+2⋅v2+…+k⋅vk&lt;br /&gt;
, unde [v1,v2,…,vk]&lt;br /&gt;
 sunt valorile distincte ale lui A&lt;br /&gt;
, ordonate crescător.&lt;br /&gt;
== Cerinţa ==&lt;br /&gt;
Fiind dat un șir de N numere naturale A, să se calculeze suma aplicării funcției f pe toate subsecvențele lui A (i.e. suma după (1 ≤ i ≤ j ≤ N) din f(A[i...j]), unde A[i…j] este subsecvența de la i la j).&lt;br /&gt;
== Date de intrare ==&lt;br /&gt;
Fișierul sortall.in conține pe prima linie numărul natural N. Linia a doua conține N numere naturale separate prin spațiu, reprezentând elementele șirului A.&lt;br /&gt;
== Date de ieșire ==&lt;br /&gt;
Fișierul sortall.out va conține răspunsul modulo 1 000 000 007.&lt;br /&gt;
== Restricţii şi precizări ==&lt;br /&gt;
* 1 ≤ N ≤ 50 000&lt;br /&gt;
* 1 ≤ Vi ≤ N&lt;br /&gt;
* Pentru 10 puncte 1 ≤ N ≤ 100&lt;br /&gt;
* Pentru alte 15 puncte 1 ≤ N ≤ 1000&lt;br /&gt;
* Pentru alte 15 puncte 1 ≤ N ≤ 5000&lt;br /&gt;
* Pentru alte 20 de puncte se garanteză că valorile din șir sunt distincte&lt;br /&gt;
== Exemplul 1 ==&lt;br /&gt;
; sortall.in&lt;br /&gt;
&lt;br /&gt;
  3&lt;br /&gt;
  1 3 2&lt;br /&gt;
; sortall.out&lt;br /&gt;
&lt;br /&gt;
  35&lt;br /&gt;
&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Exemplul 2 ==&lt;br /&gt;
; sortall.in&lt;br /&gt;
&lt;br /&gt;
  8&lt;br /&gt;
  4 3 4 4 7 1 2 1&lt;br /&gt;
; sortall.out&lt;br /&gt;
&lt;br /&gt;
  864&lt;br /&gt;
&amp;lt;br&amp;gt;&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;
MOD = 1000000007&lt;br /&gt;
&lt;br /&gt;
def solve(N, A):&lt;br /&gt;
    freq = {}&lt;br /&gt;
    total_sum = 0&lt;br /&gt;
&lt;br /&gt;
    for i in range(N):&lt;br /&gt;
        curr_sum = 0&lt;br /&gt;
&lt;br /&gt;
        for num in freq:&lt;br /&gt;
            if num &amp;lt;= A[i]:&lt;br /&gt;
                curr_sum += (i - freq[num] + 1) * num * (freq[num] - freq.get(num - 1, 0))&lt;br /&gt;
                curr_sum %= MOD&lt;br /&gt;
&lt;br /&gt;
        total_sum += curr_sum&lt;br /&gt;
        total_sum %= MOD&lt;br /&gt;
&lt;br /&gt;
        freq[A[i]] = i + 1&lt;br /&gt;
&lt;br /&gt;
    return total_sum&lt;br /&gt;
&lt;br /&gt;
def main():&lt;br /&gt;
    with open(&amp;quot;sortall.in&amp;quot;, &amp;quot;r&amp;quot;) as fin:&lt;br /&gt;
        N = int(fin.readline())&lt;br /&gt;
        A = list(map(int, fin.readline().split()))&lt;br /&gt;
&lt;br /&gt;
    result = solve(N, A)&lt;br /&gt;
&lt;br /&gt;
    with open(&amp;quot;sortall.out&amp;quot;, &amp;quot;w&amp;quot;) as fout:&lt;br /&gt;
        fout.write(str(result) + &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;
&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>RebecaBud</name></author>
	</entry>
</feed>