結果

問題 No.67 よくある棒を切る問題 (1)
ユーザー kkslucy1
提出日時 2018-04-08 19:58:26
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
AC  
実行時間 129 ms / 5,000 ms
コード長 545 bytes
コンパイル時間 1,704 ms
コンパイル使用メモリ 159,008 KB
実行使用メモリ 8,608 KB
最終ジャッジ日時 2025-03-03 11:10:49
合計ジャッジ時間 5,506 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 30
権限があれば一括ダウンロードができます
コンパイルメッセージ
In file included from /usr/include/c++/13/istream:41,
                 from /usr/include/c++/13/sstream:40,
                 from /usr/include/c++/13/complex:45,
                 from /usr/include/c++/13/ccomplex:39,
                 from /usr/include/x86_64-linux-gnu/c++/13/bits/stdc++.h:127,
                 from main.cpp:1:
In member function ‘std::basic_ostream<_CharT, _Traits>::__ostream_type& std::basic_ostream<_CharT, _Traits>::operator<<(double) [with _CharT = char; _Traits = std::char_traits<char>]’,
    inlined from ‘int main()’ at main.cpp:31:28:
/usr/include/c++/13/ostream:223:25: warning: ‘ans’ may be used uninitialized [-Wmaybe-uninitialized]
  223 |       { return _M_insert(__f); }
      |                ~~~~~~~~~^~~~~
main.cpp: In function ‘int main()’:
main.cpp:16:16: note: ‘ans’ was declared here
   16 |         double ans;
      |                ^~~

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

int main() {
	int n;
	cin >> n;
	vector<int> l(n);
	for (int i = 0;i < n;i++) {
		cin >> l[i];
	}
	long long k;
	cin >> k;

	double left = 0;
	double right = *max_element(l.begin(), l.end());
	double ans;
	for (int i = 0;i < 100;i++) {
		double mid = (left + right) / 2;
		long long count = 0;
		for (int i = 0;i < n;i++) {
			count += (int)(l[i] / mid);
		}
		if (count >= k) {
			ans = mid;
			left = mid;
		}
		else {
			right = mid;
		}
	}
	cout <<setprecision(15)<< ans << endl;


	return 0;
}
0