質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

2回答

1334閲覧

ABC_046C AtCoderくんと選挙速報

encho

総合スコア182

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2020/09/03 12:41

#ABC_046C AtCoderくんと選挙速報

##ceilの使い方について
以下の問題を解いている中でceilの使い方で不明点があるためアドバイスをいただけると幸いです。

##ABC_046C

シカのAtCoDeerくんは選挙速報を見ています。

選挙には二人の候補高橋くんと青木くんが出ています。
速報では、現在の二人の得票数の比が表示されていますが、得票数そのものは表示されていません。
AtCoDeerくんは N回画面を見て、 i(1≦i≦N)回目に見たときに表示されている比は Ti:Aiでした。
ここで、AtCoDeerくんが選挙速報の画面を1回目に見た段階で既にどちらの候補にも少なくとも一票は入っていたことがわかっています。
N回目に画面を見たときの投票数(二人の得票数の和)として考えられるもののうち最小となるものを求めてください。ただし、得票数が途中で減ることはありません。

自力では解くことができず解答を参考にしながら以下のように実装をしました。
今回問題となっているのか解答が示すn=max([A/x], [B/y])をどのように実装するかという問題です。

##解答

次に満たすべき比率かx:yだとすると、 A<=nx && B <= nyなるような最小の自然数nを取れば次にあり得る最小の得票数はnx, nyだとわかります。

このようなnはmax([A/x], [B/y])で計算できます。

##私の実装

私はnをceilを用いた計算で実装をしましたがこれでは不正解となってしまいました。
このceilを用いた式のどこに問題があるのかアドバイスをいただけると幸いです。
またこの場合はどのように実装するべきなのかもアドバイスをいただけるとありがたいです。
よろしくお願いいたします。

c++

1#include <bits/stdc++.h> 2using namespace std; 3using ll = long long; 4const long long INF = 1LL << 60; 5 6int main(){ 7 int N; 8 cin >> N; 9 vector<ll> t(N), a(N); 10 for(int i=0; i<N; i++) { 11 cin >> t[i] >> a[i]; 12 } 13 14 15 ll T = 1, A = 1; 16 for(int i=0; i<N; i++) { 17 ll n = max(ceil((double)T/t[i]),ceil((double)A/a[i])); 18 T = n * t[i]; 19 A = n * a[i]; 20 } 21 cout << T + A << endl; 22}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

このceilを用いた式のどこに問題があるのかアドバイスをいただけると幸いです。

一般的な環境ではlong longは64ビット整数なのに対して、doubleの仮数部は53ビット相当なので、doubleに変換した瞬間に精度が失われることがあります。「10の18乗以下」という計算する値に対して、doubleの53ビット相当では有効数字が16桁弱しかなく、足りません。

またこの場合はどのように実装するべきなのかもアドバイスをいただけるとありがたいです。

単純にlong longlong longで割れば、正の整数同士の除算は小数点以下が切り捨てとなります。

投稿2020/09/03 12:45

編集2020/09/03 12:50
maisumakun

総合スコア146018

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

encho

2020/09/03 13:30

大変わかりやすい説明ありがとうございます。
guest

0

ll n = max(ceil((double)T/t[i]),ceil((double)A/a[i]));

切り上げだけの話でしたら次のような公式が使えます。

C++

1// 切り上げの公式 2// 5 / 2 の切り上げ例 3// x = (a+b-1)/b 4// (5+2-1)/2 = 3 5 6ll n = max((T+t[i]-1)/t[i]),((A+a[i]-1)/a[i]); 7

参考にしたAC回答

問題ページ画面上のメニュータブの提出結果から問題名とACと自分の使う言語で検索してコード長と実効時間の速いものを上から順に数個見ると簡潔なコードが見つかるのでおすすめですよ。
十人十色のコードの書き方から学べることは多いです。

自分も以前解こうとして自力で無理だったので解説と回答だけ見てすっ飛ばしました。

投稿2020/09/03 13:26

編集2020/09/03 14:01
mjk

総合スコア303

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mjk

2020/09/03 13:29

問題で正解が出るかどうかなどは未検証です。
encho

2020/09/03 13:42

こちらの切り上げ方法でACが出せました。 ありがとうございます!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問