Makes And The Product

2024-01-13 19:18
文章标签 product makes

本文主要是介绍Makes And The Product,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

After returning from the army Makes received a gift — an array a consisting of npositive integer numbers. He hadn't been solving problems for a long time, so he became interested to answer a particular question: how many triples of indices (i,  j,  k) (i < j < k), such that ai·aj·ak is minimum possible, are there in the array? Help him with it!

Input

The first line of input contains a positive integer number n (3 ≤ n ≤ 105) — the number of elements in array a. The second line contains n positive integer numbers ai (1 ≤ ai ≤ 109) — the elements of a given array.

Output

Print one number — the quantity of triples (i,  j,  k) such that i,  j and k are pairwise distinct and ai·aj·ak is minimum possible.

Example
Input
4
1 1 1 1
Output
4
Input
5
1 3 2 3 4
Output
2
Input
6
1 3 3 1 3 2
Output
1
Note

In the first example Makes always chooses three ones out of four, and the number of ways to choose them is 4.

In the second example a triple of numbers (1, 2, 3) is chosen (numbers, not indices). Since there are two ways to choose an element 3, then the answer is 2.

In the third example a triple of numbers (1, 1, 2) is chosen, and there's only one way to choose indices.

有三种情况:

1.最小数字的个数n1>=3,则只需计算

2.n1<3,第二小的数字个数n2>=3-n1,则只需计算

3.n1,n2<3,第三小的数字个数n3>=3-n2-n1,则只需计算

注意结果会超过int

#include<iostream>
#include<queue>
#include<map>
using namespace std;
struct list
{int num,amount;list() {	}list(int a,int b):num(a),amount(b) {	}friend bool operator < (struct list c,struct list d){return c.num>d.num;} 
};
long long C(int a,int b)
{if(b>a-b)b=a-b;if(b==0)return 1;long long up=1,down=1;int i=b;while(i--)up*=a--;for(i=1;i<=b;i++)down*=i;return up/down; 
}
int main()
{int n;while(cin >> n){map<int,int> mp;priority_queue<list> q;while(n--){int a;cin >> a;mp[a]++;}map<int,int>::iterator it;for(it=mp.begin();it!=mp.end();it++)q.push(list(it->first,it->second));if(q.top().amount>=3){cout << C(q.top().amount,3) << endl;continue;}else{int num=q.top().amount;q.pop();if(q.top().amount>=3-num){cout << C(q.top().amount,3-num) << endl;continue;}else{num+=q.top().amount;q.pop();cout << C(q.top().amount,3-num) << endl;}}}return 0;
} 


这篇关于Makes And The Product的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/602508

相关文章

ural 1014. Product of Digits贪心

1014. Product of Digits Time limit: 1.0 second Memory limit: 64 MB Your task is to find the minimal positive integer number  Q so that the product of digits of  Q is exactly equal to  N. Inpu

leetcode#628. Maximum Product of Three Numbers

题目 Given an integer array, find three numbers whose product is maximum and output the maximum product. Example 1: Input: [1,2,3]Output: 6 Example 2: Input: [1,2,3,4]Output: 24 Note: The lengt

如何将Product依赖的LibraryModule导出成jar

在Android Studio新建Module时可以选择创建的module是工程module还是Android Library。 或者可以在工程module中的build.gradle文件中将 apply plugin: 'com.android.application'改为apply plugin: 'com.android.library' 同时将applicati

[LeetCode] 238. Product of Array Except Self

题:https://leetcode.com/problems/product-of-array-except-self/description/ 题目 Given an array nums of n integers where n > 1, return an array output such that output[i] is equal to the product of all

CodeForces 487C Prefix Product Sequence

题意: 构造一个1~n的排列  使得n个前缀积%n是一个0~n-1的排列 思路: 首先确定n一定放最后  要不然会有%n会有多个0  这时n-1位置的前缀积为(n-1)! 接着讨论n  n为合数时只有n=4有解  因为如果n为合数一定可以拆成p*q的形式  明显pq|(n-1)! 然后构造ai=(i+1)*inv[i]  因为(i+1)*inv[i] == (j+1)*inv[j]时一

Subtract the Product and Sum of Digits of an Integer

Given an integer number n, return the difference between the product of its digits and the sum of its digits. Example 1: Input: n = 234Output: 15 Explanation: Product of digits = 2 * 3 * 4 = 24

caffe源码解析-inner_product_layer

打开inner_product_layer.hpp文件,发现全连接层是非常清晰简单的,我们主要关注如下四个函数就行。 LayerSetUp(SetUp的作用一般用于初始化,比如网络结构参数的获取)ReshapeForward_cpuBackward_cpu ** inner_product_layer.hpp ** namespace caffe {template <typename

Largest Palindrome Product问题及解法

问题描述: Find the largest palindrome made from the product of two n-digit numbers. Since the result could be very large, you should return the largest palindrome mod 1337. 示例: Input: 2 Output: 987 E

产品为何总是做不好 (六): Product Owner 惯性的行为

2016.9.3,  北京, Ken Fang 回顾这近二十年的敏捷、软件工程的旅程,我的收获是相当的丰富的;尤其是我面对面了许多不同层级的部门领导、数千位的团队成员, 使我能不断的验证了 “人类惯性的行为“ 对团队开发效率与产品质量 (品味)的影响。 1. 当 Product Owner 惯性的行为, 只是希望能在某月某日交付版本。 2. 当 Product Owner 惯性的行为,

【PAT】【Advanced Level】1009. Product of Polynomials (25)

1009. Product of Polynomials (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue This time, you are supposed to find A*B where A and B are two pol