
再度投稿してます。
アルゴリズム初心者です。
配列Aの16×16ビットの図形データーを時計周りに90度回転し、配列Bに格納する処理内容の記述を教えて下さい。
上からI番目、、左からJ番目をA(I,J)、B(I,J)と表します。
例)配列A 配列B
1 2 3 4 5 1 2 3 4 5
1 0 0 0 0 0 1 0 0 0 0 0
2 0 1 1 1 0 2 0 1 0 1 0
3 0 0 1 0 0 3 0 1 1 1 0
4 0 1 1 1 0 4 0 1 0 1 0
5 0 0 0 0 0 5 0 0 0 0 0
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
★もしかして BASIC 出身者ですか?
・C言語で配列は A[I][J] って指定しますよ。
アルゴリズムという事なのでアドバイスしますが、横方向と縦方向を B 配列の時に
入れ替えて操作すれば良いのです。つまり、
for ( y = 0 ; y < 16 ; y++ ){
for ( x = 0 ; x < 16 ; x++ ){
B[ x ][ y ] = A[ y ][ x ];
}
}
とすれば回転に繋がります。ただし、上記の方法では時計回り90度回転にはなりませんので注意。
・Y 軸を下のほうからスキャンして X 軸の左から右に流れるように並べれば、時計回り90度回転になります。
回答を載せえると
for ( y = 0 ; y < 16 ; y++ ){
for ( x = 0 ; x < 16 ; x++ ){
B[ y ][ x ] = A[ 15 - x ][ y ];
}
}
となりますよ。単純でしょ。
・以上。おわり。

No.1
- 回答日時:
順を追って冷静に考えていくとわかってくると思います。
まず、「例」が、考えるためには不適切です。
(結果を確かめるには良いとしても)
たとえば、
1 2 3 4 5
6 7 8 9 A
B C D E F
G H I J K
L M N O P
↓
L G B 6 1
M H C 7 2
N I D 8 3
O J E 9 4
P K F A 5
こんな感じで、どの文字がどのマスにあったのかはっきりわかる形が良いと思います(たとえ、本来のデータ範囲から逸脱していても)
これを見ると、
(0, 0) "1" -> (0, 4)
(0, 1) "2" -> (1, 4)
(0, 2) "3" -> (2, 4)
(0, 3) "4" -> (3, 4)
(0, 4) "5 "-> (4, 4)
(1, 0) "6" -> (0, 3)
(1, 1) "7" -> (1, 3)
となっているわけですから、どのように割り当てたらいいか、だんだん見えてくるのではないかと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列数式の解除
-
2つ以上の変数を比較して最大数...
-
2次元動的配列の第一引数のみを...
-
ListViewで、非表示列って作れ...
-
【VBA】配列とWorksheetFunctio...
-
MATLABにて場合分け関数を定義...
-
Excel-VBAの配列「Public Const...
-
エクセルマクロで配列の値から...
-
VB6 配列を初期化したい
-
エクセルで最小値から0を除く方法
-
特定のセル範囲で4文字以上入力...
-
配列変数の添字が範囲外ですと...
-
VBAについての質問です。 こち...
-
【EXCEL自作関数】頭が揃ってな...
-
VBA Match関数の限界
-
VB.NET2015 サブルーチンの使い方
-
VBA 1次元配列を2次元に追加する
-
PL/SQLのFUNCTIONにおける引数...
-
特定のPCだけ動作しないVBAマク...
-
エクセルで特定の列が0表示の場...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列数式の解除
-
2つ以上の変数を比較して最大数...
-
特定のセル範囲で4文字以上入力...
-
VBA 1次元配列を2次元に追加する
-
subの配列引数をoptionalで使う...
-
配列変数の添字が範囲外ですと...
-
2次元動的配列の第一引数のみを...
-
ListViewで、非表示列って作れ...
-
MATLABにて場合分け関数を定義...
-
VB6 配列を初期化したい
-
AES暗号にて、AES_set_encrypt_...
-
配列を任意の数値で埋める方法
-
RPG E仕様書について
-
VBのFunctionで、配列を引数...
-
ビンゴ
-
エクセルで最小値から0を除く方法
-
順列の作成
-
VBA Match関数の限界
-
VLOOKUP関数で、一番下...
-
for each の現在の配列ポインタ...
おすすめ情報