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

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

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

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

Q&A

解決済

2回答

1065閲覧

C言語 リスト構造について

Minochan

総合スコア14

C

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

0グッド

0クリップ

投稿2018/06/28 05:24

編集2018/06/28 05:49

C言語にてリスト構造をつくり、1行の入力文字列をリスト化するというプログラムを作りました。
そのうち、入力の文字列をN個として、リストの先頭からN/2番目までの要素と、N/2+1番目から末尾までの要素を交換すると言う関数halfchangeを作ったのですが、うまく機能しません。
わかる方、教えてください。

また、実現したい実行例は以下のとおりです。

$./a.out tokyo kyoto $./a.out yuyakekoyake koyakeyuyake

実際に実行すると以下のようになります

$ ./a.out tokyo to ./a.out yuyakekoyake yuyake

C

1#include <stdio.h> 2#include <stdlib.h> 3 4struct node{ 5 char element; 6 struct node *next; 7}; 8 9struct node *initlist() { 10 struct node *n; 11 n=(struct node *)malloc(sizeof(struct node)); 12 n->next=NULL; 13 return n; 14} 15 16void insert(struct node *p, char x) { 17 struct node *n; 18 n=(struct node *)malloc(sizeof(struct node)); 19 while(p->next){ 20 p=p->next; 21 } 22 n->element=x; 23 n->next = NULL; 24 p->next=n; 25} 26 27void printlist(struct node *p) { 28 p = p->next; 29 while (p) { 30 putchar(p->element); 31 p = p->next; 32 } 33 putchar('\n'); 34} 35 36void halfchange(struct node *p) { 37 int i=0; 38 struct node *tmp=p; 39 struct node *start=p; 40 while(p->next!=NULL){ 41 i++; 42 p=p->next; 43 } 44 struct node *endp=p; 45 i=i/2; 46 47 while(i>=1){ 48 i--; 49 tmp=tmp->next; 50 } 51 struct node *half=tmp->next;//half 52 struct node *half_pre=tmp;//half-1 53 endp->next=start->next; 54 //printlist(endp); 55 half_pre->next=NULL; 56 //printlist(half); 57 p->next=half->next; 58} 59 60int main(int argc, char *argv[]) { 61 struct node *list, *head; 62 char *p; 63 64 if (argc<2) 65 exit(-1); 66 67 list = initlist(); 68 p = argv[1]; 69 for (; *p; p++) { 70 insert(list, *p); 71 } 72 73 halfchange(list); 74 printlist(list); 75 76 for (; list; ) { 77 head = list; 78 list = list->next; 79 free(head); 80 } 81 return 0; 82} 83 84 85

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

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

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

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

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

y_waiwai

2018/06/28 05:39

うまく機能しないとは、どういうふうな動作になるんでしょうか
Minochan

2018/06/28 05:50

実際にコードを実行した場合の動作を追記しましたので確認お願いします
guest

回答2

0

ベストアンサー

halfchange関数って、リストの真ん中をtmp に入れて、

struct node *half_pre = tmp;//half-1
half_pre->next = NULL;

で終端にしてしまってるだけですねー
末尾の交換の処理が入っていない

投稿2018/06/28 06:17

y_waiwai

総合スコア87774

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

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

0

こんな感じでどうでしょうか

c

1void halfchange(struct node *p) { 2 int i=0,j=0; 3 struct node *head=p; 4 struct node *tail; 5 struct node *half; 6 7 tail = p; 8 for(i=0;tail->next!=NULL;i++,tail=tail->next){ 9 } 10 11 half = p; 12 for(j=0;j<i/2;j++,half=half->next){ 13 } 14 15 tail->next = head->next; 16 head->next = half->next; 17 half->next = NULL; 18}

bash

1$ ./a.out yuyakekoyake 2koyakeyuyake 3

投稿2018/06/28 06:11

tatamyiwathy

総合スコア1039

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問