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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

Q&A

解決済

1回答

1930閲覧

java 円の中に辺1の正方形が存在する数の求めるアルゴリズム

kinako_make

総合スコア7

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

1グッド

0クリップ

投稿2020/10/01 05:47

問題は
格子状に区切られた平面の、各格子は一辺が長さ1 の正方形です。
平面を区切る縦線と横線が交差しできる点のうち、適当な一点を中心として半径 r の円をその平面上に描き、内部を黒で塗りつぶします。

このとき一部でも黒で塗られている格子の数を出力するプログラムを作成してください。

例えば
r=1.7だとしたら、格子の数は16
r=100.02651だとしたら、格子の数は31852
r は0.00001 刻みで与えられる。

いろいろ調べて格子点を数える問題は何個かあり、高校生程度の問題と書いてありましたが、よく理解できませんでした。
1から詳しく説明していただきたいです。

どうぞよろしくお願い致します。

teraHz👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

原点を中心とする円の方程式が分かればできるので、高校生程度の問題でしょう。

Java

1import java.util.Scanner; 2 3class Test { 4 public static void main(String[] args) { 5 Scanner sc = new Scanner(System.in); 6 for (;;) { 7 System.out.print("r: "); 8 if (!sc.hasNextDouble()) break; 9 double r = sc.nextDouble(); 10 int sum = 0, n = (int)r; 11 for (int i = 0; i <= n; i++) 12 sum += (int)Math.ceil(Math.sqrt(r*r - i*i)); 13 System.out.println(sum * 4); 14 } 15 sc.close(); 16 } 17}

実行例

text

1r: 1.7 216 3r: 100.02651 431852 5r: .

追記
r = 1.0 の場合、結果が 4 になって欲しいのにそうならないのは、
切り上げをちゃんとしなかったからということで、コードを修正しました。

投稿2020/10/01 08:26

編集2020/10/01 09:02
kazuma-s

総合スコア8224

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

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

kinako_make

2020/10/01 09:54

早速、ありがとうございます。 おかげで問題は解けました! 原点を中心とする円の方程式で調べたら、なんとなくですが何をしているかわかりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問