結果

問題 No.67 よくある棒を切る問題 (1)
ユーザー kou6839kou6839
提出日時 2016-04-13 17:11:22
言語 C++11
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 2,777 bytes
コンパイル時間 992 ms
コンパイル使用メモリ 104,692 KB
実行使用メモリ 10,704 KB
最終ジャッジ日時 2024-10-04 07:24:49
合計ジャッジ時間 8,535 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 244 ms
8,520 KB
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 AC 3 ms
7,624 KB
testcase_25 WA -
testcase_26 WA -
testcase_27 WA -
testcase_28 WA -
testcase_29 WA -
testcase_30 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<ctime>
#include<cctype>
#include<climits>
#include<iostream>
#include<string>
#include<vector>
#include<map>
#include<set>
#include<list>
#include<queue>
#include<fstream>
#include<deque>
#include<algorithm>
#include<numeric>
#include<utility>
#include<complex>
#include<memory>
#include<functional>

using namespace std;

#define all(g) (g).begin(),(g).end()
#define REP(i, x, n) for(int i = x; i < n; i++)
#define rep(i,n) REP(i,0,n)
#define F(i,j,k) fill(i[0],i[0]+j*j,k)
#define P(p) cout<<(p)<<endl;
#define EXIST(s,e) ((s).find(e)!=(s).end())
#define INF (1<<28)
#define pb push_back

typedef vector<int> vi;
typedef vector<vi> vvi;
typedef vector<long long> vl;
typedef vector<double> vd;
typedef pair<int, int> pii;
typedef pair<long, long> pll;
typedef long long ll;

int gcd(int a, int b) {
	if (b == 0) return a;
	return gcd(b, a % b);
}

int lcm(int a, int b) {
	return a / gcd(a, b) * b;
}

int extgcd(int a, int b, int& x, int& y) {
	int d = a;
	if (b != 0) {
		d = extgcd(b, a % b, y, x);
		y -= (a / b) * x;
	}
	else {
		x = 1; y = 0;
	}
	return d;
}

bool is_prime(ll n) {
	if (n == 2) return true;
	if (n % 2 == 0) return false;
	for (ll i = 3; i * i <= n; i+=2) {
		if (n % i == 0) return false;
	}
	return n != 1;
}

vector<int> divisor(int n) {
	vector<int> res;
	for (int i = 1; i * i <= n; i++) {
		if (n % i == 0) {
			res.pb(i);
			if (i != n / i) res.pb(n / i);
		}
	}
	return res;
}

map<int, int> prime_factor(int n) {
	map<int, int> res;
	for (int i = 2; i * i <= n; i++) {
		while (n % i == 0) {
			++res[i];
			n /= i;
		}
	}
	if (n != 1) res[n] = 1;
	return res;
}

const int MAX_N = 10000000;
int prime[MAX_N];
bool memo[MAX_N + 1];
long long MOD = 1000000007ll;
ll mod_pow(ll x, ll n, ll mod) {
	if (n == 0) return 1;
	ll res = mod_pow(x * x % mod, n / 2, mod);
	if (n & 1) res = res * x % mod;
	return res;
}

vector<int> G[100005];
int dp1[1000005], dp2[100005];
void dfs(int p, int x) {
	vi child;
	for (int v : G[x]) {
		if (v != p) child.push_back(v);
	}

	for (int v : child)dfs(x, v);

	ll prod = 1;
	for (int v : child) prod = prod*dp1[v] % MOD;
	dp2[x] = prod;

	ll prod2 = 1;
	for (int v : child) prod2 = prod2*dp2[v] % MOD;
	dp1[x] = (dp2[x] + prod2) % MOD;
}
int trans(int n) {
	int ret = 0;
	while(n > 0) {
		ret += (n % 10)*(n % 10);
		n /= 10;
	}
	return ret;
}

int N;
vector<int> L;
ll K;
bool check(double a) {
	int count = 0;
	for (int b : L) {
		count += b / a;
	}
	return count >= K;
}
int main() {
	cin >> N;
	rep(i, N) {
		int a;
		cin >> a;
		L.pb(a);
	}
	cin >> K;

	double min = 0, max = 1000000010;
	rep(i, 120) {
		double mid = (min + max) / 2;
		if (check(mid)) {
			min = mid;
		}
		else {
			max = mid;
		}
	}
	P(min);


	return 0;
}
0