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

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

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

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

C++

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

Q&A

解決済

1回答

777閲覧

for文でネストした文字列と数字から距離を求めたい。

ashiseidou

総合スコア7

C

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

C++

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

0グッド

0クリップ

投稿2021/08/07 07:39

Cでプログラミングをしていてわからなかったことがありましたのでここに記します。
問題があり、
#で囲まれたマップがあります。その中に数字がいくつか記載されております。Nと書かれた地点から数字までの距離で、近い順にソートを行いたいと思っております。

#include <iostream> #include<math.h> using namespace std; int main() { int H, W; char s_i; cin >> H; cin >> W; for (int i = 0; i < H; i++) { for (int j = 0; j < W; j++) { cin >> s_i; cout << s_i << endl; } } return 0; }

s_iで自動的に#と数字とNが記載され、これでネストはできますが。以下のようになります。間違えていたら申し訳ございません。

######4 ####### ##1#N## ##2#### #3#####

この結果から1,2,4、3となると思われます。つまり、Nから数値が書かれた距離を調べるやり方及び、ソートを教えてほしいのです。
分かる方おられましたら、よろしくお願いします。因みに、上下左右でしか、測れないものとします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

Cでプログラミングをしていてわからなかったことがありましたのでここに記します。

<iostream> を使うということは C ではなく、C++ ですね。

マップを読み込む変数を用意しなければなりません。
C なら 2次元配列、C++ なら vector の vector。
質問のデータなら、次のようになるでしょう。
a[0][6] = '4'
a[2][2] = '1'
a[2][4] = 'N'
a[3][2] = '2'
a[4][1] = '3'

'N' から '4' までの距離は |0-2| + |6-4| = 4
絶対値は abs関数が使えます。

追記
よく考えたら、マップは読み込む必要はありませんね。
N と各数字の座標を憶えておくだけで済みます。

追記2
距離を求める部分は示しますので、ソートは自分でやってください。

C++

1#include <iostream> 2#include <vector> 3#include <cstdlib> // abs 4using namespace std; 5 6struct X { 7 char c; 8 int x, y; 9 int dist; // N からの距離 10 11 X(int c, int x, int y) : c(c), x(x), y(y) { } 12}; 13 14int main() 15{ 16 int H, W; 17 cin >> H >> W; 18 vector<X> v; 19 int n = 0; 20 for (int i = 0; i < H; i++) { 21 for (int j = 0; j < W; j++) { 22 char c; 23 cin >> c; 24 if (c != '#') { 25 if (c == 'N') n = v.size(); 26 v.push_back(X(c, i, j)); 27 } 28 } 29 } 30 for (int i = 0; i < v.size(); i++) { 31 v[i].dist = abs(v[i].x - v[n].x) + abs(v[i].y - v[n].y); 32 cout << v[i].c << " (" << v[i].x << ", " << v[i].y << ") " 33 << v[i].dist << endl; 34 } 35}

実行結果

text

15 7 2######4 3####### 4##1#N## 5##2#### 6#3##### 74 (0, 6) 4 81 (2, 2) 2 9N (2, 4) 0 102 (3, 2) 3 113 (4, 1) 5

もちろん、このコードは参考になるかもしれないものであり、
距離を求めるところを自分で考えてみてもよいでしょう。

投稿2021/08/07 07:54

編集2021/08/07 08:34
kazuma-s

総合スコア8224

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

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

ashiseidou

2021/08/07 09:34

ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問