정수 유형 요소의 배열이 주어지고 주어진 배열에서 쌍을 형성하고 쌍에 있는 요소의 합을 계산하고 주어진 합이 4로 나누어 떨어지는지 여부를 확인하는 작업입니다.
입력 - 정수 arr[] ={4, 1, 2, 0, 2}
출력 − 합이 4로 나누어 떨어지는 배열의 카운트 쌍은 − 2
설명 − 주어진 배열에서 만들 수 있는 쌍은 다음과 같습니다. (4, 1) =5(4로 나눌 수 없음), (4, 2) =6(4로 나눌 수 없음), (4, 0) =4(나누기 4), (1, 2) =3(4로 나누어 떨어지지 않음), (1, 0) =1(4로 나누어 떨어지지 않음), (2, 0) =2(4로 나누어 떨어지지 않음), (2, 2) ) =4(4로 나눌 수 있음), (0, 2) =2(4로 나눌 수 없음). 따라서 합이 4로 나누어지는 쌍은 (4, 0) 및 (2, 2)입니다.
입력 - 정수 arr[] ={2, 4, 8, 6, 10}
출력 − 합이 4로 나누어 떨어지는 배열의 카운트 쌍은 − 4입니다.
설명 - 주어진 배열에서 만들 수 있는 쌍은 다음과 같습니다. (2, 4) =6(4로 나눌 수 없음), (2, 8) =10(4로 나눌 수 없음), (2, 6) =8(나누기 4), (2, 10) =12(4로 나눌 수 있음), (4, 8) =12(4로 나눌 수 있음), (4, 6) =10(4로 나눌 수 없음), (4, 10) =14(4로 나누어 떨어지지 않음), (8, 6) =14(4로 나누어 떨어지지 않음), (8, 10) =18(4로 나누어 떨어지지 않음), (6, 10) =16(4로 나누어 떨어지지 않음). 따라서 합이 4로 나누어 떨어지는 쌍은 (2, 10), (2, 6), (4, 8) 및 (6, 10)입니다.
아래 프로그램에서 사용된 접근 방식은 다음과 같습니다.
주어진 문제를 해결하기 위한 여러 가지 접근 방식, 즉 순진한 접근 방식과 효율적인 접근 방식이 있을 수 있습니다. 먼저 순진한 접근 방식을 살펴보겠습니다. .
-
정수 요소의 배열을 입력하고 배열의 크기를 계산하고 데이터를 함수에 전달
-
합계가 4로 나누어지는 쌍의 개수를 저장하기 위해 임시 변수 개수를 선언합니다.
-
배열의 크기까지 i에서 0까지 FOR 루프 시작
-
루프 내에서 배열의 크기까지 j에서 i + 1까지 FOR 또 다른 루프를 시작합니다.
-
루프 내에서 합계를 arr[i] + arr[j]로 계산하고 IF sum % 4 ==0을 확인한 다음 카운트를 1씩 증가시킵니다.
-
개수 반환
-
결과를 인쇄합니다.
효율적인 접근
-
정수 요소의 배열을 입력하고 배열의 크기를 계산하고 데이터를 함수에 전달
-
합계가 4로 나누어지는 쌍의 개수를 저장하기 위해 임시 변수 개수를 선언합니다.
-
4로 나눌 수 있는지 확인해야 하므로 크기가 4인 배열을 만듭니다.
-
배열의 크기까지 i에서 0까지 FOR 루프 시작
-
루프 내에서 temp를 arr[i] % 4로 설정하고 배열을 ++check[temp]
로 사전 증가시킵니다. -
카운트를 new_arr[0] * (new_arr[0] - 1)/2
로 설정 -
카운트를 count + new_arr[2] * (new_arr[2] - 1)/2
로 설정 -
count를 count + new_arr[1] * new_arr[3]
로 설정 -
개수 반환
-
결과를 인쇄하십시오.
예(순진한 접근 방식)
#include <iostream> using namespace std; int pair_4(int arr[], int size){ int count = 0; for(int i = 0 ;i <size ; i++){ for(int j = i+1; j<size; j++){ int sum = arr[i] + arr[j]; if(sum % 4 == 0){ count++; } } } return count; } int main(){ int arr[] = {4, 1, 2, 0, 2}; int size = sizeof(arr) / sizeof(arr[0]); cout<<"Count pairs in array whose sum is divisible by 4 are: "<<pair_4(arr, size); return 0; }
출력
위의 코드를 실행하면 다음 출력이 생성됩니다 -
Count pairs in array whose sum is divisible by 4 are: 2
예시(효율적인 접근)
#include <iostream> using namespace std; int pair_4(int arr[], int size){ int temp = 0; int count = 0; int check[] = {0, 0, 0, 0}; for (int i = 0; i < size; i++){ temp = arr[i] % 4; ++check[temp]; } count = check[0] * (check[0] - 1) / 2; count = count + check[2] * (check[2] - 1) / 2; count = count + check[1] * check[3]; return count; } int main(){ int arr[] = {4, 1, 2, 0, 2}; int size = sizeof(arr) / sizeof(arr[0]); cout<<"Count pairs in array whose sum is divisible by 4 are: "<<pair_4(arr, size); return 0; }
출력
위의 코드를 실행하면 다음 출력이 생성됩니다 -
Count pairs in array whose sum is divisible by 4 are: 2