c
1#include <stdio.h> 2#include <stdlib.h> 3int main() { 4 int a[N] = { 1,2,3,4,5,6,7,8,9,10 }; 5 int b[N]; 6 int *p, *q; 7 int i; 8 p= //何かを代入 9 q= //何かを代入 10 //配列aを出力する 11 //while文を使って、逆順コピーのプログラムをかく。ただし、aとpとqを使用する。 12 //配列bを出力する 13 return 0; 14}
//実行例
a [] : 1 2 3 4 5 6 7 8 9 10
b [] : 10 9 8 7 6 5 4 3 2 1
先生は、この方法で書いて来いといわれました。
僕は、pにはaのアドレスを、qにはbのアドレスを代入する?
配列aの出力はfor文で、というところまではなんとなくイメージできるのですが、そこから先が分かりません。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答7件
0
Cなど不要。そう、シェル芸ならね!
bash
1$ echo 1 2 3 4 5 6 7 8 9 10|xargs -n1|tail -r|xargs 210 9 8 7 6 5 4 3 2 1
追記
Windowsなら、PowerShell芸にまかせろ!
PS> $a = 1,2,3,4,5,6,7,8,9,10 PS> $b = $a[($a.length-1)..0] PS> "$b" 10 9 8 7 6 5 4 3 2 1
投稿2018/04/29 13:00
編集2018/04/29 13:21総合スコア5737
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2018/04/29 13:01
2018/04/29 13:07
2018/04/29 13:21 編集
0
配列aの出力はfor文で、というところまではなんとなくイメージできるのですが、そこから先が分かりません。
イメージ出来てるところまで、とりあえずコードを書きましょう。
一歩踏み出せば、周りの景色も変わってくるのだから・・・
投稿2018/04/29 12:31
編集2018/04/29 12:58退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/04/29 13:04
0
回答例のコードが既に示されていますが、
べつ方法 (bの末尾からではなく、先頭か値を埋めていく) と、コードの整形をしたものを示します。
a.c
c
1#include <stdlib.h> 2 3#define N (10) 4 5void print_array(int * array, char * name) { 6 printf("%s[] :", name); 7 for (int i = 0; i < N; i++) { 8 printf(" %2d", array[i]); 9 } 10 printf("\n"); 11} 12 13int main() { 14 int a[N] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; 15 int b[N]; 16 17 print_array(a, "a"); 18 19 // while文を使って、逆順コピーのプログラムをかく。ただし、aとpとqを使用する。 20 int * p = &a[N - 1]; 21 int * q = b; 22 while (p != a) { 23 *q++ = *p--; 24 } 25 26 print_array(b, "b"); 27 28 return 0; 29}
整形のポイントは次の点です。
- メソッド定義してコードの繰り返しを避けた (配列の内容表示)
- 必要な処理の直前で変数定義をする。
投稿2018/05/01 12:48
総合スコア22324
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
問題がむずかしかったら時も対処法には次のものがあります。
- 問題を分割して、もっと簡単な問題の組み合わせにする。
- 類似しているが、もっと簡単な問題をまずは解く、それを元にして目的の問題を解く。
今回は、まずは、逆順でなく、同じ順次でコピーするようにしてみては?
それができたら、すこし変更するだけで逆順にコピーできるのと思います。
先頭から順番にとってきて末尾から置いていくか、
末尾から順番にとってきて、先頭から置いていくかの2つの方針が考えらえれます。
(これは方針2の考えから)
方法2 の考えかたをするなら、
A. そのままコピーする, B. 配列を逆順にする
の2つの方法をみつけて、コピーしてから逆順にすることで問題が解けます。
でもこの方法は今回のゴールのコーディングの形とは異なったものになってしまうとおもわれますが...
投稿2018/04/29 22:58
編集2018/04/30 03:41総合スコア22324
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
ベストアンサー
コード
c
1#include <stdio.h> 2#include <stdlib.h> 3 4#define N (10) 5 6int main() { 7 int a[N] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; 8 int b[N]; 9 int *p, *q; 10 int i; 11 12 p = &a[0];//何かを代入 13 q = &b[N-1];//何かを代入 14 15 //配列aを出力する 16 printf("a[] :"); 17 for (i = 0; i < N; i++) { 18 printf(" %d", a[i]); 19 } 20 printf("\n"); 21 22 //while文を使って、逆順コピーのプログラムをかく。ただし、aとpとqを使用する。 23 while (p != &a[N]) { 24 *q-- = *p++; 25 } 26 27 //配列bを出力する 28 printf("b[] :"); 29 for (i = 0; i < N; i++) { 30 printf(" %d", b[i]); 31 } 32 printf("\n"); 33 34 return 0; 35}
出力
a[] : 1 2 3 4 5 6 7 8 9 10 b[] : 10 9 8 7 6 5 4 3 2 1
投稿2018/04/29 19:07
総合スコア317
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
ヒントだけ書いておきます。
a [] : 1 2 3 4 5 6 7 8 9 10
b [] : 10 9 8 7 6 5 4 3 2 1
aの0番目はbの9番目
aの1番目はbの8番目
...
aの9番目はbの0番目となりますよね?
これをもとにaのi
番目はbの何番目かi
を使って表すことができます。
それをfor
文かwhile
文で処理して表示すればいいです。
投稿2018/04/29 14:07
退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。