Problem Statement:
The e-commerce company ‘Easy Shopping’ displays some specific products for its premium customers on its user interface. The company shortlisted a list of N products. The list contains the price of each product. The company will select random products for display. The selection criteria states that only those products whose price is a perfect cube number will be selected for display. The selection process is automated and is done by the company’s system. The company wishes to know the total count of the products selected for display.
Write an algorithm to find the count of products that will be displayed.
The first line of the input consists of an integer – numProducts, representing the number of products(N).Output Format:
The second line consists of N space-separated integers – price0, price1,…,priceN-1 representing the product price of the N shortlisted products.
Print an integer representing the number of products that will be selected for display.Constraints:
0<=numProducts<=10^6Sample Input:
0<=price<=10^6
6
125 216 54 81 48 343
Sample Output:
3
Solution in | C | JAVA | PYTHON |
---|
#include<stdio.h>
int main() {
int n, prices[50],i,j,max,count=0;
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d",&prices[i]);
}
max = prices[0];
for(i=0;i<n;i++){
if(max<prices[i]){
max = prices[i];
}
}
j=1;
while(j*j*j<=max){
for(i=0;i<n;i++){
if(j*j*j==prices[i]){
count++;
}
}
j++;
}
printf("%d",count);
return 0;
}
int main() {
int n, prices[50],i,j,max,count=0;
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d",&prices[i]);
}
max = prices[0];
for(i=0;i<n;i++){
if(max<prices[i]){
max = prices[i];
}
}
j=1;
while(j*j*j<=max){
for(i=0;i<n;i++){
if(j*j*j==prices[i]){
count++;
}
}
j++;
}
printf("%d",count);
return 0;
}