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

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

ただいまの
回答率

88.92%

xy平面上の点と原点の距離を求めたい。

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 331

yeoum

score 0

xy平面上の10個の点(0~9番とすると)のxy座標を入力すると、原点に最も近い点までの距離とその点の番号を出力するプログラムを作りたいです。
また、同条件で、互いに最も近い2点間の距離とその2点の番号を出力するプログラムを作りたいです。

配列を用いて作ってみたのですが上手くいきませんでした。
もしよろしければご協力よろしくお願いします。

コードは以下の通りで、if文の条件式から分からなくなりました。

#include <stdio.h>
#include <math.h>

#define N 10

int main(void)
{
    int i, j;
    double x[N], y[N], d[N], min;

    for(i = 0; i < N; i++) {
        printf("x[%1d] = ? ", i);
        scanf("%lf", &x[i]);
        printf("y[%1d] = ? ", i);
        scanf("%lf", &y[i]);
        d[i] = sqrt(x[i] * x[i] + y[i] * y[i]);
        if (d[i])
    }

    return 0;
}
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • episteme

    2020/07/20 09:11

    質問は編集できます。
    そのコードは質問の中に。

    キャンセル

  • yeoum

    2020/07/20 09:15

    丸投げするような質問でした。
    大変申し訳ありませんでした。

    キャンセル

  • キャンセル

回答 4

checkベストアンサー

+1

「入力された x[10] の中から最も小さい x[i]を見つけ、i と x[i] をプリントする」なら、できますか?

[追記] できてないみたいなので

// 入力された x[10] の中から最も小さい要素のインデクスと値をプリントする
#include <stdio.h>
#include <math.h>

#define N 10

int main(void) {
  int i;
  double x[N] = { 9.9, 7.7, 5.7, 3.7, 1.1, 2.2, 4.4, 6.6, 8.8, 10.10 };

  // とりあえず、「0番目が一番小さい」ことにしておく
  int min_index = 0;
  double min_value = x[0];
  for ( i = 0; i < N; i++) {
    // より小さい値を見つけたら記録更新
    if ( min_value > x[i] ) {
      min_index = i;
      min_value = x[i];
    }
  }

  printf("min-index=%d min-value=%lf\n", min_index, min_value);

  return 0;
}

これが理解できるなら
「入力された x[i],y[i](i=0~N-1) の中から原点からの距離が最も小さい要素の
インデクスと値をプリントする」
まであと一歩。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/07/20 09:48

    例えばminを10000など大きな数としたとき、以下のようにしたのですが出力結果が明らかに違ってしまいます。
    if (min >= d[i]) {
    min = d[i];
    printf ("最小距離 = %d", d[i])
    }

    キャンセル

  • 2020/07/20 09:57

    僕の問いに答えていません。
    「入力された x[10] の中から最も小さい x[i]を見つけ、i と x[i] をプリントする」
    ができれば、件の問題はその応用です。

    キャンセル

  • 2020/07/20 19:15

    皆様回答ありがとうございました。
    アドバイスを参考に解決出来ました。

    キャンセル

+1

int i, j;
double x[N], y[N], d[N], min, tmp;

for(i = 0; i < N; i++) {
    printf("x[%1d] = ? ", i);
    scanf("%lf", &x[i]);
    printf("y[%1d] = ? ", i);
    scanf("%lf", &y[i]);
    d[i] = sqrt(x[i] * x[i] + y[i] * y[i]);//ここsqrtは要らないかも
    //if (d[i]) このif分は不要。
}

//この後でソートのプログラムを記入すれば良いと思います。
//    参考URL
//https://qiita.com/omu58n/items/7e2a1055a42ef738ab8b

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/07/20 17:36

    min の初期値は「x[0],y[0] から求めた距離」でもえぇですな。

    キャンセル

  • 2020/07/20 18:05

    d[0]の値ですね。
    確かに...
    ループ回数が一つ減るから、そっちでも良いですね。

    キャンセル

  • 2020/07/20 19:16

    皆様回答ありがとうございました。
    アドバイスを参考に解決出来ました。

    キャンセル

+1

10個の点をいちいちキー入力していられないのでそこは改変。ご自分でscanfに書き替えてください。

原点からの距離は、今回の問題では各点ごとに保存する必要はありません。現在の点の距離dと、これまでの最小の距離min_dだけで十分です。

xyは、この後「任意の2点間の距離」を求める処理を書くかもしれないので保存しておきます。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define N 10
#define P_MIN -10
#define P_MAX 10

int main(void)
{
    double x[N], y[N];
    srand(time(NULL));

    double min_d = sqrt(P_MAX * P_MAX * 2);
    int min_i = -1;
    for (int i = 0; i < N; i++) {
        x[i] = (double)rand() / RAND_MAX * (P_MAX - P_MIN) + P_MIN;
        y[i] = (double)rand() / RAND_MAX * (P_MAX - P_MIN) + P_MIN;
        double d = sqrt(x[i] * x[i] + y[i] * y[i]);
        //printf("%d番目の点(%5.2lf, %5.2lf)の原点からの距離は%5.2lf\n", i, x[i], y[i], d);
        if (d < min_d) {
            min_d = d;
            min_i = i;
        }
    }

    printf("原点からの距離が最小なのは%d番目の点(%5.2lf, %.2lf)で、距離は%5.2lf\n", min_i, x[min_i], y[min_i], min_d);

    return 0;
}

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/07/20 19:16

    皆様回答ありがとうございました。
    アドバイスを参考に解決出来ました。

    キャンセル

+1

配列は使わなくてもできます。

#include <stdio.h>  // printf, scanf
#include <math.h>   // hypot

#define N 10

int main(void)
{
    int min_index = 0;
    double x, y, min_value;
    for (int i = 0; i < N; i++) {
        printf("x[%d] = ? ", i), scanf("%lf", &x);
        printf("y[%d] = ? ", i), scanf("%lf", &y);
        double d = hypot(x, y);  // 底辺 x、高さ y の直角三角形の斜辺
        if (i == 0 || d < min_value) min_value = d, min_index = i;
    }
    printf("min-index=%d min-value=%lf\n", min_index, min_value);
}

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/07/20 19:16

    皆様回答ありがとうございました。
    アドバイスを参考に解決出来ました。

    キャンセル

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

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る