C言語なら俺に聞け 148
■ このスレッドは過去ログ倉庫に格納されています
JPCERTに書いてある > DCL12-C. 抽象データ型は opaque な型を使って実装する これ、言葉遣いが JIS に準拠してないね - opaque な型 + 不完全型 あのね opaque を「おぱきゅー」と読むとね、 中がどうなっているか見えないって感じがヒシヒシ伝わるんだよ。 >>5 寧ろ向こう側が透けて見えて意味を取り違えそうな… 不可視を不完全と呼ぶのはちょっと良くないと思うわ まあ視点が違うんだけども みんなmusl libcとか使ってたりする? プロジェクトの内容だけみると けっこう良さげなんだけど あまり日本語の情報を聞かないし 実際はglibcとかが大半なのかな。 c言語本格入門のリスト構造(単方向リスト)が理解できず困っています。 書籍には図を書けば理解できるとあり、ソースにprintf関数をところどころに入れて、ポインタの動きを追いかけていたのですが、余計こんがらがってしまいます。 他のサイトや他者の質問が掲載された掲示板なども参考にしましたが、さっぱりわかりません。 図を描いても理解には繋がりません。 プログラムは250行くらいあり、掲載出来る様なサイトがあれば誘導お願いします。 ポインタの*ptr_now、*ptr_before、*ptr_new の動きと役割が理解できれば、前に進めると思うのですが、知恵を貸して下さい。 nowが今いる所でbeforeがさっきいた所でnewが新たに作る所? >>18 now と before は作業用領域で、newは名前とかを格納しています。 >>18 とある位置に新しいデータを挿入するサンプルコードなんじゃないか? newが新たに挿入しようとするデータのアドレス、 nowが挿入先の直後のデータのアドレス、 beforeが挿入先の直前のデータのアドレス。 (単方向リストへのデータ挿入は新しいデータを挿入する位置の前後のデータのアドレスが必要のため) ところでnowってスケジュールリストか何かなのか >>18 努力しているようだが、色々おかしい。 > ソースにprintf関数をところどころに入れて、ポインタの動きを追いかけていたのですが ポインタの『動き』ではなく、ポインタの『中身』を追いかけろ。 ポインタは自然言語で言う「ポイントする(指し示す)もの」でしかないから、 正しい物を示しているかどうかだけであって、 それはポインタ自体ではなく、『中身』を見ないと判定出来ない。 > 単方向リスト > *ptr_now、*ptr_before、*ptr_new 単方向リストならポインタは一つだけだし、 > now と before は作業用領域で、newは名前とかを格納しています。 名前の付け方が絶望的におかしい。 多分君の理解が間違っているだけだと思うが、 もしその理解が正しくて、ガチでこんな名前を付けているソースなら、 その本は今すぐ捨てるべきだ。 これはソースを上げれば誰かが見てくれるだろう。 (多分>>22 が当たりだろう) 当たり前だが、 1. まず、0,1,2,3... とリストに入れて、それを表示(リストアップ)出来る関数を作れ。 2. 次に、その関数を用いて、挿入等したとき、期待通りにリストアップ出来るか確認しろ。 3. それでバグっているようなら、その後でいちいちIDE等で止めてポインタの値を確認するんだよ。 多分お前はデバッグの仕方もおかしい。 ただまあ正直なところ、このレベルの初心者ならリストなんてどうせ使わないし、 スキップしても構わんぞ。いちいち全部やらなくてもいい。 そんなことより、ゲームを作りたいのならそのゲームを作る方向目指してコーディングしろ。 そのうち、ポインタ等の意味も分かってきて、今回の問題なんて自然に解決出来るようになる。 >>22 ちなみに細かいようだが、 > (単方向リストへのデータ挿入は新しいデータを挿入する位置の前後のデータのアドレスが必要のため) 実際の所、単方向リストなら struct List { T value; // または T* ptr; T* next; }; だから、ループは now と next だけで構成しないと筋が悪いんだけどね。 ソート済みリストでデリミタがヌルポなら、 while (now->next && value <= next->value) now = next; // 同値なら挿入順 で now を確定させ、now と next の間に挿入する。 nowは「今」、newが「新」として、beforeは余計だね。 何かの説明をする為なのだろうけど、余計におかしくなってる。 (挿入するのは『nowとnext』の間であって、『beforeとnow』の間ではない) >>24 駄目な事を駄目だとはっきり言っただけだ。 怒られたことのないゆとりには噛みついているようにしか見えないのかもしれないが、 このレベルの駄目っぷりを駄目出ししてもらえない方が問題だろ。 これが許容出来ないのなら、コテハン制の他サイトに行けよ。 どんなアホな投稿でも優しく教えてくれるだろうさ。 ただそれが本人の為になるかどうかはまた別だが、ゆとりにはお似合いだ。 右も左も分かってない馬鹿なんだから普通にIDE使えよ。 printfデバッグなんて(IDEが有料だった昔はさておき) 今のそのレベルの初心者がやるもんじゃない。 まあしかし、お前がそういうのならお前が導いて見せろ。 出来もしないのに文句だけ言うのもゆとりの特徴だとも思うがね。 てゆーかマジな話、250行って何だよ? 27のリストなら精々50行だろ。 色々根本的におかしい。 本ではなく、18が根本的に間違ってるんだと思うが。 >>21 名前ってまさか構造体の名前じゃないよね・・? >>18 その250行と、printf() を入れてみたけれどもうまくいかなかった、という printf() の挿入場所をこちらに貼ってください https://ideone.com 話はそれから うまい釣りだ。このままじらしてじらしていつまでもソースを公開しなければこのスレは活性化して書き込みで溢れあっという間に3スレぐらい消費するだろう。流石としか言いようがない。 低学歴知恵遅れには質問の意味が理解できない 普通に質問の内容を再現すればだいたいこうなる typedef struct tag_aho_list_t { char new[0x10]; t_aho_list_t* next; } t_aho_list_t; ptr_new = (t_aho_list_t*)malloc(sizeof(t_aho_list_t)); strcpy(ptr_new->name, "aho1"); ptr_before = ptr_now; ptr_now = ptr_new; ptr_before->next = ptr_now; ptr_new = (t_aho_list_t*)malloc(sizeof(t_aho_list_t)); strcpy(ptr_new->name, "aho2"); ptr_before = ptr_now; ptr_now = ptr_new; ptr_before->next = ptr_now; >>33 お前も絶望的にダサいコードを書くな。 追加なら、 > ptr_before = ptr_now; > ptr_now = ptr_new; > ptr_before->next = ptr_now; ではなくて、 ptr_now->next = ptr_new; ptr_now = ptr_new; だろ。 つか、単方向リストで before を使う時点で間違い。 >>36 マジでIDE使え。 そして貼るときはlanguageをCにしとけ。シンタックスハイライトが変わるから。 で、どれが分からんの? > enter > find > delete > show_all > delete_all mainはこの際分からなくていい。 最初に理解しないといけないのは show_all だ。 ただし細かいことを言ってもキリがないが、 > void show_all(void) なんだこれ?引数 void って初めて見たぞ。文法的にありなのかこれ? さらに酷いのは show_all 内でグローバル変数 address を掴んでいること。 普通は void show_all(tag_address* ta) だよ。 そうじゃないと複数のリストがあったときに使い物にならないだろ。 マジな話、このソースのレベルの本なら捨てた方がいい。 俺は大学の教材がいいと思うぞ。 (読んでないが)リストならググったら東工大とか出てきた。 http://www.is.titech.ac.jp/compview/clang/chap11.html voidはアリだぞ。 仕事だとなぜかvoidを書けと言われるわ >>37-38 void show_all() が引数無しの意味になるのはC++。 Cだと show_all(...) と同じ意味になって何渡してもコンパイル通っちゃうからあぶない。 >>38 マジかーと思って linux kernel のコード見たが、書いてるな。 そして K&R 見てみたら、なんとこれも書いてた。 旧来の記法なら書くのが正しくて、物によってはコンパイル通らないとかか? とにかく、 void がクソだというのは取り下げる。 >>39 > Cだと show_all(...) と同じ意味になって何渡してもコンパイル通っちゃうからあぶない。 マジ?今まで聞いたこと無かったわ。 しかし ( ... ) と同じ意味なら例の va_list を使う糞コードになるから、 コンパイラのチェックが甘くなるとはいえ、間違って使うって事はなさそうだが。 まあとにかくありがとう。 >>36 何度も言ってるがマジでIDE使え。 次にマジでこの本はソースがおかしいから捨てた方がいい。処理のフローがクレイジーだ。 何かおかしな規約に沿って書いているように思える。 178-205行目は、普通なら以下。 while(ptr_now != NULL && no >= ptr_now->no) { if (no == ptr_now->no) { if (address == ptr_now) address = ptr_now->next; else ptr_before->next = ptr_now->next; free(ptr_now); return 0; } ptr_before = ptr_now; ptr_now = ptr_now->next; } return -1; >>36 ちなみに一応ちゃんとポインタで書いておくと、以下な。 whileの条件は分けた方が分かりやすいか? 書き込みターゲットは一つに纏める。 int delete(int no, tag_address* ptr_now) { tag_address** ptr_tgt = &ptr_now; while(ptr_now != NULL) { if (no == ptr_now->no) { *ptr_tgt = ptr_now->next; free(ptr_now); return 0; } if (no < ptr_now->no) return -1; ptr_tgt = &ptr_now->next; ptr_now = ptr_now->next; } return -1; } すまん、42は間違い。 引数を&で受けても意味無いな。書き直す。 >>36 、42の訂正版 int delete(int no, tag_address** ptr_head) { tag_address** ptr_tgt = ptr_head; tag_address* ptr_now = *ptr_head; while(ptr_now != NULL) { if (no == ptr_now->no) { *ptr_tgt = ptr_now->next; free(ptr_now); return 0; } if (no < ptr_now->no) return -1; ptr_tgt = &ptr_now->next; ptr_now = ptr_now->next; } return -1; } 君には余計に分かりにくくなったかもしれないけど、こんな感じ。 まあ頑張れ。 >>36 enter関数も作りがおかしい。 25で言ったとおり、 > (挿入するのは『nowとnext』の間であって、『beforeとnow』の間ではない) このソースは before と now の間に挿入しており、明らかに間違ってる。 マジでこの本はゴミだから捨てろ。 まあいいんじゃね? 処理内容毎に塊を分けて上から順番に並べているのは他人にわかりやすく説明するために都合がいいのだと思う。 きっと書籍では、N行目からM行目まではこんなことをしてます、とか、塊毎に処理内容のコメントが記述されてるのではないかと思う。 >>46 いやこれはさすがにアウトだろ。 実際部下にこのコード出されたら絶句するだろ。 178行目と194行目のヌルチェックなんてダブってるし、マジで意味無い。 頭が悪い奴が一生懸命書いたコードだぞこれは。手本にするには酷すぎる。 delete関数は筆者には難しすぎて、異常系を一つずつ外して行ってるから無駄にダブってる。 だけどこの規模でこれだと絶望的だろ。 マジでこの本は捨てた方がいい。 18が読めないのは18の技量の問題だけど、 読みやすいコードと読みにくいコードというのは実際にあって、 要するに腕前がいい奴が書いたコードは一般的に読みやすく、下手くそが書いたコードは読みにくい。 (勿論高速化等かけた場合は若干読みにくくなるが) 頭が悪いのなら、関数を分けて分割すべきであって、 breakして下に無理矢理繋げているから意味不明なコードになる。 なお高速コードは以下。 int delete(int no, tag_address** ptr_head) { tag_address** ptr_tgt = ptr_head; tag_address* ptr_now = *ptr_head; while(ptr_now != NULL && no >= ptr_now->no) { ptr_tgt = &ptr_now->next; ptr_now = ptr_now->next; } if (ptr_now != NULL && no == ptr_now->no) { *ptr_tgt = ptr_now->next; free(ptr_now); return 0; } else return -1; } もともこもないこというけど カーネルの list.h 使え C言語で A,B,C,D,E,F,G,H,I,J,K,Lの12個のペアを、3個ずつの4つのグループに分ける場合 例えばA,BとA,CとD,Eは同じグループに入れないとして、実行時には(ADF,BCE,GHI,JKL)みたいな感じで返すプログラミングの書き方の例を教えてください >>39 が言ってることすら知らないID:16ZpsTnK0が偉そうに講釈たれてて笑うわ >>49 その例だと目的が分からないから、 それを何に使いたいのか具体例で書いてくれ。 >>45 このソースでは「beforeとnowの間にnewを挿入」するenter()で正しく動作するね。 リストの定常状態で、各要素はメンバnoの値で昇順整列している。 ポインタnextのつなぎ換えをする時点で、 beforeのnoは新要素のnoより小さい、nowのnoは新要素のnoより大きい、 よって new->next = now, before->next = new と格納すれば before->no < new->no < now->no の順序が維持される。 ただし境界条件(リストの端っこの処理)はここでは考えていない。 変数やメンバの命名をもう少し工夫すれば…と思うけど。 この投稿を書いててnewとnow、メンバnoで混乱してきた。 リスト操作に特化した関数を作ればいいのに リスト操作といろんな処理を混ぜ込むから見通しが悪くなってる 教育目的ならなおのこと美しく書かないといけないのに >>37 >> void show_all(void) > >なんだこれ?引数 void って初めて見たぞ。文>法的にありなのかこれ? この程度の知識でも偉そうに講釈垂れる事が出来るのがこのスレです >>52 そりゃ糞コードでも動くだろうさ。 しかし教科書でこれはない。マジであり得ないくらい酷い。 必要のない変数を作って保持してるだろ。 走査は25に書いたとおり、(書き落とした点を修正するが) while (now->next && value <= now->next->value) now = now->next; でやるんだよ。そうすれば now と next だけの世界で済む。 enter()も頂けない。これは>>53 の指摘通り、 int insert(tag_address* ta) と tag_address* make_new_element(int no, char* name, char* addr) に分けないと駄目だ。 マジでここまで酷いのはなかなか見かけないくらい酷い。 部下がこんなコード書いたら当然突き返す会社が大半だと思うぞ。 例も酷い。これは List ではなく SortedList だし、 そもそもこれをやりたいのならCではなくC++でやるべきだし。 >>54 そこで俺叩きに転じてるのが逆に、お前が馬鹿である証拠だ。 このコードは擁護のしようがないくらい酷い。ど素人でもここまで酷いコードは書かない。 お前にはそれが分からないから俺を叩こうとしてる。 お前みたいな初心者は文法のことばかり気にするが、文法の細かいところは本当に関係ないんだよ。 俺はC++コンパイラを使っているから>>39 は関係なかったし、 >>38 はそうじゃないから void を書くルールになってるんだろ。 そういうもんなんだよ。 文法的に問題があるケースはルールで禁止されてるか、環境で対策されてる。 まあ俺に文法知識が欠けているのは事実としても、この本がゴミなのは揺るがない。 理由は筆者が馬鹿だから、だから、マジですぐに捨てて他の本/サイトを参考にした方がいい。 嘘だと思うのなら、この事を覚えておいて、 数年後、お前らが上達してからもう一度このコードを見直して見ろ。絶句するから。 ちなみに余談だが K&R の良い点は、糞コードがないこと、余分な表現がないこと、なんだよ。 無駄を限界まで削ぎ落とした、極めて上質なコードが掲載されている。 筆者が頭が良く、一流のプログラマだからだ。 実際の所、入門書は総じてゴミだ。 これは入門書を書く奴は一般的に一流のプログラマではないからだ。 だから入門書のコードはマジで参考にしない方がいい。 今回のは特に。 お前らが上達すれば、このコードの酷さが分かるようになるだろうさ。 今回の顛末を覚えておいて、数年後に見直して見ろ。マジで。 >>57 うんそだね〜 でもどんな言い訳してもここはC言語スレだしCプラプラコンパイラと言えどCの文法書けるわけだし 初心者に偉そうに講釈垂れるならCの最 低 限の文法くらい知ってた方がいいよ >>59 ならお前も18に対して何か為になるレスをしてから言えよ。 お前が俺に粘着する理由が分からん。 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 >>56 これをやりたいならC++でやるべき、って C言語の入門書のコード例なのに何を言ってるんだ? かまってちゃんなんだろう、相手してもらって嬉しそうだ >>61 そりゃそうだろ。 俺が文法を知らなかったことは本筋とは関係ないし、 実際、お前ら以外気にしてないだろ。 お前らは役に立つレスを全くしてないし、ただの粘着荒らしでしかない。 なお>>39 、知ってるかもしれんが以下だそうな。 > C99にて廃止予定機能となった。C11でどうなったかは不明 http://d.hatena.ne.jp/eel3/20141005/1412521223 仕様に詳しい人よろしく。 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 >>62 その点は既にC++で対策されてるから。 書けば分かるが、その例のSortedListなら、C++で書いた方が綺麗に書ける。 C++はその点を対策した言語なのだから、当たり前だが。 >> void show_all(void) > >なんだこれ?引数 void って初めて見たぞ。文法的にありなのかこれ? 以下のコード見たことありまちゅか〜?wwww #inlcude <stdio.h> int main(void) { printf("Hello World!"); return 0; } こういう簡単なコードの書き方なら 喜々として低学歴知恵遅れのシロウトが喜々として一杯よってくる つか、粘着馬鹿共は誰も役に立つことを言えてない件。 お前らが俺に粘着する意味は何なんだ? なお>>18 、一番近いのは std:forward_list でソース例は以下だが、 https://github.com/gcc-mirror/gcc/blob/master/libstdc%2B%2B-v3/include/bits/forward_list.h 毎回思うがGNUは別の意味で読みづらいから(マクロまぶしすぎ) 今の君には無理だが、可能ならこれを読んだ方がいい。最終的な目標にしとけ。 >>37 で既に示した東工大、斜め読みしたが、 1. before 関数 を使って list_add 関数を修正して p の「直後」に挿入 2. before 関数 だから明らかにこっちの方が筋がいい。 2の意味は分からないだろうが、これはコンパレーターであり、関数ポインタに繋がる。 こちらはそもそも教育の現場、やはりちゃんとしている。 こっち使った方がいいと思うぞ。 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 低学歴知恵遅れはこの程度のコードしか 理解できないのがよくわかるわ まず質問と関係ない内容で喜々として得意になってレスしてる こういう簡単な内容ならめっちゃ元気 ああ、そういえば一応>>18 には直球で返した方がいいか?なら、 *ptr_now:今エレメント *ptr_before:前エレメント *ptr_new:新エレメント であり、まんまそのままだ。 ただ、単方向リストで before は履歴が必要だから、このコードは筋が悪い。 単方向リストなら、出来る限り、 *ptr_now:今エレメント *ptr_next:次エレメント で構成されるべきで、この場合には履歴が要らないからより単純なコードになる。 そして東工大はそうだからそっちを参考にしろ、というわけ。 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 コードがどういう書かかたされてるとか 質問してるヤツは一切してないからな コレは低学歴知恵遅れの自分が理解できてる範囲のことを コレは低学歴知恵遅れがひたすら連騰してるだけだからな つまりこの質問ではどうでもいいただのコードの書き方 質問してるヤツはどういう動作をして どうデータが格納されてるかを質問してる 低学歴知恵遅れはなんでまともに日本語が読めないわけ まともな教育とは思えないわ。。。 (正)まともな教育を受けてるとは思えないわ。。。 (誤)まともな教育とは思えないわ。。。 つまり まともな教育を受けてない低学歴知恵遅れが このスレにきた初心者にえらそうにしてるわけ わかる? >>73 てかマジでこれが助けになると思ってるのか? お前もしかして18なの? なら絶望的に頭悪いし、プログラミングなんて止めた方がいい。 そしてもしこの回答を得る為にひたすら単発で煽っていたのなら、マジでウザイから止めろ。 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 >>74 ならお前が回答してやれよw お前も回答出来ただろうし、お前はそれが役に立つと思ってたんだろ。 よくわからんけどその本の後の方の章でそのコードを改良して双方向リストの説明でもしてるんじゃないの? 入門書とかだとよく前の章のコードの説明を元に段階的に説明していく場合があるけど >>77 双方向リストでもこの意味分からん処理フローにはならないし、 関数ポインタを見据えている東工大の方が数段筋がいいよ。 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 入門書だぞ? 汎用性や高速性なんて二の次どころか入門書では不要かもしれない。 ポインタの理解も危うい段階でダブルポインタとかlist.hを提示するとか狂気の沙汰だわ。 もしもID:16ZpsTnK0が入門書を書いたらいきなりハードモードでそれこそ役に立たないから即捨て間違いないわ こんな簡単な質問の回答能力があるヤツはいないか まずenter()関数をみなさい まず一回目のenter()で動く箇所はココになる while (ptr_now != NULL) { ・・・ ← ココ } if (address == NULL){ ・・・ ← ココ } それ以外は 一回目と一回目以外、enter()では同じ 次にココをみなさい if (no < ptr_now->no) { break; } if (address->no > ptr_new->no){ address = ptr_new; printf("address(enter)=%p\n", address); } ココでなにやってるか 次に考えなさい https://ideone.com/F3xZFe >>36 のコードをCのコードの設定にしてやったから まずenter()とshow_all()の結果をみなさい >>81 ならお前がまず何か役に立つ回答をしてから言えよ。 お前だって > *ptr_now:今エレメント > *ptr_before:前エレメント > *ptr_new:新エレメント は回答出来ただろうに。(何故か>>73 には感謝されてるようだし) 半角君は少なくとも自分で説明しようとしている分、お前ら粘着単発馬鹿共より数段ましだぜ。 ダブルポインタ云々ではなく、18はまず、 1. リスト構造自体を理解出来ていない 2. 多分ポインタも怪しい 3. そもそも全くプログラムが追えてない だから、IDEで全関数の頭にブレークポイントで気が済むまでステップ実行させるべきだろ。 printfデバッグなんて何でこいつがやる必要があるんだ? このレベルの入門書ならIDEの使い方から教えるべきだろ。 そして教科書のコードはそれとなしに汎用性があるコードであるべきなのさ。 東工大はこれを満たしてる。この本は全然駄目だ。その違いだよ。 勿論東工大は最初からEcilpse + CDTだ。 http://www.is.titech.ac.jp/compview/clang/chap1.html 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 ただマジな話、18はプログラミングは全く駄目なタイプだと思うぞ。 数学の素養/素質がない奴は、努力しても上達しない。 プログラミングは暗記で対応出来るものではないから。 プログラミング自体を止めた方がいいと思うよ。マジで。 printfで十分わかるからな IDEは低学歴知恵遅れに必要 >なんだこれ?引数 void って初めて見たぞ。文法的にありなのかこれ? >なんだこれ?引数 void って初めて見たぞ。文法的にありなのかこれ? >なんだこれ?引数 void って初めて見たぞ。文法的にありなのかこれ? 👀 Rock54: Caution(BBR-MD5:1341adc37120578f18dba9451e6c8c3b) むしろ ID:16ZpsTnK0 ← コイツ が一番プログラミングに向いてない その自覚がない しかも相当自分の頭の悪さの自覚がない 致命的 そもそもデバッグライトは プロのプログラミングの世界では重要な技術要件だからな 問題が発生したとき 速やかに問題点の発見ができるようにする助けになるのが デバッグライト 問題が発生したとき まずデバッグモードでコンパイルしてデバッグライトの出力して なぜ問題が発生しているか原因をすみやかに発見する 幾重にも重なった巨大なシステムになるほどデバッグライトの出力は重要になる 役に立つわかりやすい適切なデバッグライトを書けるか書けないかで だいたいそいつのオツムの程度が分かる 今日はいつもの「低学歴知恵遅れ」の人 ID:PGp2AKzL0 と 新たに登場した ID:16ZpsTnK0 の東工大ファンの人がいるのか。 さらにいえば低学歴知恵遅れに作らせると 一切ログが出力されない知恵遅れなシステムになる エラーとしか出力されない もしくはエラーが発生してハズなのに正常終了して 停止せずに次の処理にいってしまう 一応東工大の全部読んだぞ。 俺は東工大の教材の方がずいぶんましだと思うが。 概ね初心者向けによく書けてる。(当たり前だが) > int main() { > struct schedule* list = NULL; > list = list_add(list, 2009, 1, 1, 0, "元旦"); 毎回書き戻すこのインタフェースについては若干検討の余地ありだけども、 ダブルポインタも難しいというのならこれでも致し方無しか。 ただこれだとインミュータブルの言語では複数ヶ所から使用出来なくなるから、 やはりオブジェクト指向で list->add() と書く癖を付けた方がいいし、 リストなんて使いたければ素直にC++使えってことだと思うけどね。 「C言語本格入門」はゴミだから今すぐ捨てろ、マジで。 まあ>>36 のコードのゴミっぷりが分からないうちは大口叩くのは止めとけ。 そしてこれを覚えておいて、数年後に見直してみろ。 俺が何言ってたか分かるから。 >>91 ファンではないぞ。偶々ググったらヒットしただけ。 ただ、概ね大学の講義資料は良く出来てるよ。 これまでも、他大学を含めて何度もURL貼ったことがある。 (良く出来ているのが検索上位に来るだけかもしれないが、 それでもそれを有り難く利用させてもらえばいい) >>85 えー、あなたより先にそれ答えたけど。 単発idはnvno業者のせいなんで文句言われても困る。 ちょっとポインタで躓いたくらいでやめたほうがいいとかどんだけハードル高いんだよ。 あなたは下っ端が向いてそうだから間違っても後輩の教育係にはならんようにな。 まずオマエの場合、 自分がゴミでクズの低知能の低学歴知恵遅れの自覚がない そこが問題 講義用のプリント読んでもその程度だからな とりあえず、人に説明するのにやたらと攻撃的だったり高圧的だったりする奴は向いてないな。 低学歴知恵遅れがなにも理解できてないのに 分かったつもりになれる そういう意味で東工大のプリントは優秀 ■ このスレッドは過去ログ倉庫に格納されています
read.cgi ver 07.5.0 2024/04/24 Walang Kapalit ★ | Donguri System Team 5ちゃんねる