Doti divi veseli skaitļi N gadiem K uzdevums ir atrast pirmo N naturālo skaitļu moduļu K summu, t.i., 1%K + 2%K + ..... + N%K.
Piemēri:
propozicionālā loģika
Input : N = 10 and K = 2. Output : 5 Sum = 1%2 + 2%2 + 3%2 + 4%2 + 5%2 + 6%2 + 7%2 + 8%2 + 9%2 + 10%2 = 1 + 0 + 1 + 0 + 1 + 0 + 1 + 0 + 1 + 0 = 5.Recommended Practice Reversā kodēšana Izmēģiniet to!
1. metode:
Iterējiet mainīgo i no 1 līdz N, novērtējiet un pievienojiet i%K.
Tālāk ir sniegta informācija par šīs pieejas īstenošanu.
C++// C++ program to find sum of // modulo K of first N natural numbers. #include using namespace std; // Return sum of modulo K of // first N natural numbers. int findSum(int N int K) { int ans = 0; // Iterate from 1 to N && // evaluating and adding i % K. for (int i = 1; i <= N; i++) ans += (i % K); return ans; } // Driver Program int main() { int N = 10 K = 2; cout << findSum(N K) << endl; return 0; }
Java // Java program to find sum of modulo // K of first N natural numbers. import java.io.*; class GFG { // Return sum of modulo K of // first N natural numbers. static int findSum(int N int K) { int ans = 0; // Iterate from 1 to N && evaluating // and adding i % K. for (int i = 1; i <= N; i++) ans += (i % K); return ans; } // Driver program static public void main(String[] args) { int N = 10 K = 2; System.out.println(findSum(N K)); } } // This code is contributed by vt_m.
Python3 # Python3 program to find sum # of modulo K of first N # natural numbers. # Return sum of modulo K of # first N natural numbers. def findSum(N K): ans = 0; # Iterate from 1 to N && # evaluating and adding i % K. for i in range(1 N + 1): ans += (i % K); return ans; # Driver Code N = 10; K = 2; print(findSum(N K)); # This code is contributed by mits
C# // C# program to find sum of modulo // K of first N natural numbers. using System; class GFG { // Return sum of modulo K of // first N natural numbers. static int findSum(int N int K) { int ans = 0; // Iterate from 1 to N && evaluating // and adding i % K. for (int i = 1; i <= N; i++) ans += (i % K); return ans; } // Driver program static public void Main() { int N = 10 K = 2; Console.WriteLine(findSum(N K)); } } // This code is contributed by vt_m.
PHP // PHP program to find sum // of modulo K of first N // natural numbers. // Return sum of modulo K of // first N natural numbers. function findSum($N $K) { $ans = 0; // Iterate from 1 to N && // evaluating and adding i % K. for ($i = 1; $i <= $N; $i++) $ans += ($i % $K); return $ans; } // Driver Code $N = 10; $K = 2; echo findSum($N $K) 'n'; // This code is contributed by ajit ?> JavaScript <script> // JavaScript program to find sum // of modulo K of first N natural // numbers. // Return sum of modulo K of // first N natural numbers. function findSum(N K) { let ans = 0; // Iterate from 1 to N && evaluating // and adding i % K. for(let i = 1; i <= N; i++) ans += (i % K); return ans; } // Driver Code let N = 10 K = 2; document.write(findSum(N K)); // This code is contributed by code_hunt </script>
Izvade:
5
Laika sarežģītība: O(N).
Palīgtelpa: O(1)
2. metode:
Izmantojot šo metodi, rodas divi gadījumi.
1. gadījums: kad N< K katram skaitlim i N >= i >= 1, darbojoties ar moduli K, dos i rezultātu. Tātad nepieciešamā summa būs pirmā N naturālā skaitļa N*(N+1)/2 summa.
2. gadījums: kad N >= K tad veseli skaitļi no 1 līdz K naturālu skaitļu secībā radīs 1 2 3 ..... K - 1 0, kā rezultātā, ja darbosies ar moduli K. Līdzīgi no K + 1 līdz 2K tas iegūs tādu pašu rezultātu. Tātad ideja ir saskaitīt, cik reižu šī secība parādās, un reizināt to ar pirmo K - 1 naturālo skaitļu summu.
Tālāk ir sniegta informācija par šīs pieejas īstenošanu.
C++// C++ program to find sum of modulo // K of first N natural numbers. #include using namespace std; // Return sum of modulo K of // first N natural numbers. int findSum(int N int K) { int ans = 0; // Counting the number of times 1 2 .. // K-1 0 sequence occurs. int y = N / K; // Finding the number of elements left which // are incomplete of sequence Leads to Case 1 type. int x = N % K; // adding multiplication of number of // times 1 2 .. K-1 0 sequence occurs // and sum of first k natural number and sequence // from case 1. ans = (K * (K - 1) / 2) * y + (x * (x + 1)) / 2; return ans; } // Driver program int main() { int N = 10 K = 2; cout << findSum(N K) << endl; return 0; }
Java // Java program to find sum of modulo // K of first N natural numbers. import java.io.*; class GFG { // Return sum of modulo K of // first N natural numbers. static int findSum(int N int K) { int ans = 0; // Counting the number of times 1 2 .. // K-1 0 sequence occurs. int y = N / K; // Finding the number of elements left which // are incomplete of sequence Leads to Case 1 type. int x = N % K; // adding multiplication of number of times // 1 2 .. K-1 0 sequence occurs and sum // of first k natural number and sequence // from case 1. ans = (K * (K - 1) / 2) * y + (x * (x + 1)) / 2; return ans; } // Driver program static public void main(String[] args) { int N = 10 K = 2; System.out.println(findSum(N K)); } } // This Code is contributed by vt_m.
Python3 # Python3 program to find sum of modulo # K of first N natural numbers. # Return sum of modulo K of # first N natural numbers. def findSum(N K): ans = 0; # Counting the number of times # 1 2 .. K-1 0 sequence occurs. y = N / K; # Finding the number of elements # left which are incomplete of # sequence Leads to Case 1 type. x = N % K; # adding multiplication of number # of times 1 2 .. K-1 0 # sequence occurs and sum of # first k natural number and # sequence from case 1. ans = ((K * (K - 1) / 2) * y + (x * (x + 1)) / 2); return int(ans); # Driver Code N = 10; K = 2; print(findSum(N K)); # This code is contributed by mits
C# // C# program to find sum of modulo // K of first N natural numbers. using System; class GFG { // Return sum of modulo K of // first N natural numbers. static int findSum(int N int K) { int ans = 0; // Counting the number of times 1 2 .. // K-1 0 sequence occurs. int y = N / K; // Finding the number of elements left which // are incomplete of sequence Leads to Case 1 type. int x = N % K; // adding multiplication of number of times // 1 2 .. K-1 0 sequence occurs and sum // of first k natural number and sequence // from case 1. ans = (K * (K - 1) / 2) * y + (x * (x + 1)) / 2; return ans; } // Driver program static public void Main() { int N = 10 K = 2; Console.WriteLine(findSum(N K)); } } // This code is contributed by vt_m.
PHP // PHP program to find sum of modulo // K of first N natural numbers. // Return sum of modulo K of // first N natural numbers. function findSum($N $K) { $ans = 0; // Counting the number of times // 1 2 .. K-1 0 sequence occurs. $y = $N / $K; // Finding the number of elements // left which are incomplete of // sequence Leads to Case 1 type. $x = $N % $K; // adding multiplication of number // of times 1 2 .. K-1 0 // sequence occurs and sum of // first k natural number and // sequence from case 1. $ans = ($K * ($K - 1) / 2) * $y + ($x * ($x + 1)) / 2; return $ans; } // Driver program $N = 10; $K = 2; echo findSum($N $K) ; // This code is contributed by anuj_67. ?> JavaScript <script> // Javascript program to find sum of modulo // K of first N natural numbers. // Return sum of modulo K of // first N natural numbers. function findSum(N K) { let ans = 0; // Counting the number of times // 1 2 .. K-1 0 sequence occurs. let y = N / K; // Finding the number of elements // left which are incomplete of // sequence Leads to Case 1 type. let x = N % K; // adding multiplication of number // of times 1 2 .. K-1 0 // sequence occurs and sum of // first k natural number and // sequence from case 1. ans = (K * (K - 1) / 2) * y + (x * (x + 1)) / 2; return ans; } // Driver code let N = 10; let K = 2; document.write(findSum(N K)); // This code is contributed by _saurabh_jaiswal </script>
Izvade:
5
Laika sarežģītība: O(1).
Palīgtelpa: O(1)