再度投稿してます。
アルゴリズム初心者です。
配列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で質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# 10人分の生徒の英語の点数{32,34,41,38,40,26,14,46,42,50} と数学の点 2 2022/05/26 21:31
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Ruby 初心者プログラミング 3 2022/10/12 11:31
- C言語・C++・C# C#の問題です。 文字列型の配列 s[100] にキーボードから入力された100文字以内の文字列(単 2 2022/06/22 15:18
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- PHP 配列の値の更新方法について 1 2022/08/05 09:49
- Visual Basic(VBA) VBA横データを縦にしたいです 2 2023/08/08 19:38
- PHP クラス 1 2022/08/08 15:12
- Visual Basic(VBA) ExcelVBAで質問です。離れた二次元配列を一つにしたい 4 2022/07/26 19:06
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列数式の解除
-
ListViewで、非表示列って作れ...
-
2つ以上の変数を比較して最大数...
-
VB6 配列を初期化したい
-
[Excel2000_VBA] 型が一致しま...
-
Excel-VBAの配列「Public Const...
-
VBA 1つの列を3つ以上の条件で...
-
配列で飛び飛びの値を指定して...
-
VBA 1次元配列を2次元に追加する
-
友愛数を探すプログラム
-
VLOOKUP関数で、一番下...
-
Array配列の末尾に追加したい。
-
2次元動的配列の第一引数のみを...
-
for each の現在の配列ポインタ...
-
えfor文とか使っちゃう時点で時...
-
AES暗号にて、AES_set_encrypt_...
-
VB2008: CSV を二次元配列に読...
-
VBA Match関数の限界
-
VBAで多次元配列のインデックス...
-
配列変数の添字が範囲外ですと...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列数式の解除
-
2つ以上の変数を比較して最大数...
-
VBA 1次元配列を2次元に追加する
-
特定のセル範囲で4文字以上入力...
-
for each の現在の配列ポインタ...
-
VBのFunctionで、配列を引数...
-
subの配列引数をoptionalで使う...
-
VB6 配列を初期化したい
-
ListViewで、非表示列って作れ...
-
配列変数の添字が範囲外ですと...
-
Excel-VBAの配列「Public Const...
-
2次元動的配列の第一引数のみを...
-
VBAで近似曲線の係数取得
-
VLOOKUP関数で、一番下...
-
配列に同じ値を入れる方法
-
エクセルで最小値から0を除く方法
-
linest関数に配列を渡す
-
配列を任意の数値で埋める方法
-
Dim は何の略ですか?
-
配列内の内容を全て表示する方法
おすすめ情報