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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

3回答

1088閲覧

c言語、図式化 array

退会済みユーザー

退会済みユーザー

総合スコア0

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2018/01/28 09:30

編集2018/02/16 14:20

int i;
int j;

for (i = 0, j = len -1; i < j; i = i + 1, j = j - 1) { c = array[i]; array[i] = array[j]; array[j] = c; }

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

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

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

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

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

guest

回答3

0

ベストアンサー

図式化とはおそらくフローチャートにすることを言っているのだと思いますが、パソコンで図を書くのはしんどいのでそれは省略します。
ソースコードをもとに図式化というよりは、図式化してからソースコードを書くという方が順序的には正しいような気もしますが。

端同士を交換するという発想でよいと思います。
配列の要素数が n だと分かっているのだから、配列の前から i 番目の要素と交換すべき要素は (n-i-1) 番目ですよね。
そして、この交換は真ん中までやればよいです。要素数が奇数のときのど真ん中については交換に含めても含めなくてもよいですが、 hichon さんのように xor 交換アルゴリズムを用いる場合は問題が出てしまいますし、含める必要もないので含めなくてよいかと思います。逆に真ん中を越えて行うとどうなるかはお分かりだと思いますので省略します。

これらをふまえると次のように書けます。
分かりやすさのため値を交換する SWAP(a,b) マクロは用意したとします。
直接ここに交換アルゴリズムを書いてももちろん大丈夫です。

c

1char str[] = "everyone"; 2 3// サイズ n を求める 4// sizeof(char) == 1 は固定なので本当はいらないですが。 5int n = sizeof(str) / sizeof(char); 6 7// (文字列の場合) 終端文字を含んでしまうのですが、 8// 終端文字をひっくり返して先頭にもってきてしまうと困るので、 9// 最後の終端文字を除外して反転させるために、長さを 1 引きます。 10// 最初から strlen() でもよいと思います。 11// 純粋に配列を反転させる場合はいりません。 12n--; 13 14// ここからが本題 15// 先の考察の通り、真ん中までループして、対応する要素同士を 16// 入れ替えます。真ん中は含まないことにしたので、条件は < です。 17for (int i = 0; i < n / 2; i++) { 18 // i 番目の要素と、 (n-i-1) 番目の要素を交換する 19 SWAP(str[i], str[n-i-1]); 20} 21 22// (おまけ) ひっくりかえした後の文字列を表示 23printf("%s\n", str);

投稿2018/01/28 10:47

Eki

総合スコア429

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

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

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

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

Eki

2018/01/28 11:16

おお!そんなサービスもあるんですね...すごい。
guest

0

こんな漢字で、

c

1#include <string.h> 2 3void reverse(char *str) { 4 if (str) { 5 char *end = str + strlen(str) - 1; 6 while (str < end) { 7 *str ^= *end; 8 *end ^= *str; 9 *str ^= *end; 10 str++; 11 end--; 12 } 13 } 14}

投稿2018/01/28 10:05

hichon

総合スコア5737

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問