1 名前:デフォルトの名無しさん [2008/10/01(水) 07:28:51 BE:151474728-PLT(18888)] あなたが解けないC言語/C++言語の宿題を片付けもらうスレッドです。気に入らない質問やその他や発言はスルーの方向で。 【質問者へ】 回答者の便宜のため、質問の際は以下を行うことを推奨します。 ・質問は【質問テンプレ】を利用してください。 ・問題文は、出題されたまま全文を書いてください。 ・問題文やコードをリンクするときは、一言内容にについて説明をつけましょう。 ・計算問題は数式をあげ、どのような計算をするのか詳しく説明してください。 ・エラーは、その詳細と発生した行を書きましょう。エラーメッセージはコピペしてください。 ・後から問題に付け足しするのはコラー!!です。付け足しは作業を無駄にしがちです。 ・なりすましを防ぐため、トリップを使ってください。名前欄に、「#」に続けて任意の文字列を入力して投稿すると、その文字列を知らない他人に騙られることを防ぐことができます。 【質問テンプレ】 [1] 授業単元: [2] 問題文(含コード&リンク): [3] 環境 [3.1] OS: (Windows/Linux/等々) [3.2] コンパイラ名とバージョン: (gcc 3.4 VC 6.0等) [3.3] 言語: (C/C++/どちらでも可 のいずれか) [4] 期限: ([yyyy年mm月dd日hh:mmまで] または [無期限] のいずれか) [5] その他の制限: (どこまで習っているか、標準ライブラリは使ってはいけない等々) 【アップローダー==ラウンジ】(質問が長い時はココ使うと便利 回答者もコードが長ければここに) kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/joyful.htm 【C 関数検索 man on WWW】 www.linux.or.jp/JM/index.html 【過去ログ検索】 chomework.sakura.ne.jp/ 【wiki】 www23.atwiki.jp/homework/ 前スレ C/C++の宿題を片付けます 115代目 pc11.2ch.net/test/read.cgi/tech/1217741118/
369 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 03:24:27 ] >>368 質問者でもない者に対して丁寧に細かくありがとう>< エンディアンそっちのけでバイナリデータ見てた俺のバカ!
370 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 03:32:57 ] まっ、麻呂のクソースはいらんかえぇ〜〜?
371 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 07:20:45 ] >>361 テキストにした時点で精度が落ちてるから元には戻せないよ
372 名前:デフォルトの名無しさん [2008/10/16(木) 08:49:22 ] [1] 授業単元: プログラミング [2] 問題文(含コード&リンク): 英文を入力すると、単語に分割して出力するプログラムを書く。 ただし、ピリオドとカンマは出力しないようにすること。 (実行例) 英文を入力してください: There is , a textbook. --- There is s textbook --- [3] 環境 [3.1] OS: Linux [3.2] コンパイラ名とバージョン: gcc [3.3] 言語: C [4] 期限: 来週の木曜日 [5] その他の制限: 出来ればプログラミング下手な自分にもわかるように解説を付けてくれると助かります。 よろしくお願いします。
373 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 09:40:15 ] >>372 #include <stdio.h> #include <string.h> int main(void){ char buf[256]; char *p; printf("英文を入力してください:(255文字まで)\n"); fgets(buf, 256, stdin); p = buf; p = strtok(buf, " ,.\n"); while (p) { printf("%s\n", p); p = strtok(NULL, " ,.\n"); } return 0; }
374 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 10:04:36 ] [1] 授業単元:プログラミング [2] 問題文(含コード&リンク): まず大きな正方形のエリアがあり その大きな正方形の中に小さな正方形のエリアがある。 次に大きな正方形の線上で2点を取る。(一方は左下に固定) 左下の固定点と入力した大きな正方形の線上の二点を線で結び その直線が中の小さい正方形に重なるか重ならないかを判定する [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン:gcc [3.3] 言語:C [4] 期限:10月中 [5] その他の制限:特になし 考えてみたけどさっぱりわかりません 正方形の大きさは変えられると助かります よろしくお願いします。
375 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 11:21:02 ] 数学知識に遥かにウェイトがある問題に言語の技巧の問題を 組み合わせた課題を出す教師は...
376 名前:デフォルトの名無しさん [2008/10/16(木) 11:29:00 ] 一般化すれば、 平面座標内に正方形と直線があり 交わりがあるかどうかを調べる
377 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 11:33:00 ] >>374 (数学の解) まず直線の傾きとy切片を求め直線の式を作れ y = ax + b 次に小さい正方形のx座標を代入してその値とy座標の値を比較 a * x1 + b - y1 a * x2 + b - y2 a * x3 + b - y3 a * x4 + b - y4 4つの正負が同じなら重ならない 1個でも負号が違えば重なる 0は適当にどちらかに決めて処理 ↓ Cでプログラム
378 名前:デフォルトの名無しさん [2008/10/16(木) 11:34:54 ] より一般化すれば、凸多角形の共通部分や、 多角形ポリゴン同士の衝突判定をしたいのですが。。。 だ。 Spaghetti Source - 凸多角形の共通部分 www.prefield.com/algorithm/geometry/convex_intersect.html 多角形ポリゴン同士の衝突判定をしたいのですが。。。 - 教えて!goo oshiete1.goo.ne.jp/qa675246.html
379 名前:374 mailto:sage [2008/10/16(木) 11:42:23 ] ありがとうございます 書き忘れて申し訳ないのですが二次元で大丈夫です >>377 さん 左下を原点とすれば切片0は可能ですよね? Cの知識がなさすぎて組めないorz
380 名前:デフォルトの名無しさん [2008/10/16(木) 13:32:11 ] [1] 授業単元:プログラミング [2] 問題文(含コード&リンク): bmp画像の各ピクセルごとの数値を読み込み、 二次元配列として表示するプログラムを作成せよ [3] 環境 [3.1] OS:Windows [3.2] コンパイラ名とバージョン:Visual Studio 2005 [3.3] 言語:C [4] 期限:10月中 [5] その他の制限:特になし まったく見当がつきません。 よろしくお願いします
381 名前:デフォルトの名無しさん [2008/10/16(木) 13:34:45 ] [1] 授業単元:c++builder [2] 問題文(含コード&リンク):下に提示 [3] 環境 [3.1] OS:windows xp [3.2] C++ builder5 [3.3] 言語:C++ builder [4] 期限: 10/17まで Memo1には Memo2には Memo3には Memo4には 5 4 5 2 6 3 2 6 5 1 8 4 6 4 6 6 と出してあるのですがこの4つのMemoの列に対応させて足し算したものを Memo5に 16 17 18 22 と出したいのですがどのようにすればいいんでしょうか。 builderに関してほとんど手探り状態なのでどなたかわかる方よろしくお願いします。
382 名前:デフォルトの名無しさん [2008/10/16(木) 13:58:13 ] 見当つかないんだったらフォーマットくらい調べろよ できるかもしれないじゃんか
383 名前:デフォルトの名無しさん [2008/10/16(木) 15:10:05 ] C++で2分法のf(x)=X*X-2 プログラムよろしくお願いします。
384 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 15:19:35 ] >>379 合ってるかどうかは知らない あと、くそーすだがあしからず #include <stdio.h> int main(void) { double x, y, a, tmp; int i; //大きな正方形の座標(左下、右下、左上、右上) double large_x[4] = {0.0, 10.0, 0.0, 10.0}; double large_y[4] = {0.0, 0.0, 10.0, 10.0}; //小さな正方形の座標(左下、右下、左上、右上) double small_x[4] = {5.0, 7.0, 5.0, 7.0}; double small_y[4] = {1.0, 1.0, 3.0, 3.0}; printf("大きな正方形の線上の点"); scanf("%lf %lf", &x, &y); a = y / x; tmp = a * small_x[0] - small_y[0]; for(i=1; i<4; i++){ if( tmp * (a * small_x[i] - small_y[i]) <= 0.0 ) break; } if(tmp > 0.0) printf("重ならない\n"); else printf("重なる\n"); return 0; }
385 名前:デフォルトの名無しさん [2008/10/16(木) 15:19:42 ] #include <stdio.h> #define GOSA 0.0001 float sqr(float c){ double x=c,y; while(1){ y=x*x; if(y>c-GOSA)if(y<c+GOSA)break; x -= (y-c)/(2*x);} return x; }
386 名前:デフォルトの名無しさん [2008/10/16(木) 15:19:46 ] [1] 授業単元:情報処理演習2 [2] 問題:1.大きさ5の配列の各要素に整数データを読み込みながら順次格納して、全要素を逆に並びかえて、その配列の0番から順に内容を表示するプログラムをつくりなさい 2.正整数を順次配列に読み込んで、三番目に大きな数(全て大きい数なら、左から三番目の数)を出力するプログラムを作れ。尚、0を読み込むと終了すること ただし、必ず3個以上を読み込むと仮定してもよい [3] 環境 [3.1] OS:Linux [3.2] gcc [3.3] 言語:C [4] 期限 16日の23:59分まで お願いします
387 名前:デフォルトの名無しさん [2008/10/16(木) 15:20:40 ] >>385 は X*X=cを解くプログラムね
388 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 15:50:49 ] >>386 (1) #include<stdio.h> int main(){ int a[5],i,left,right; for(i=0;i<5;++i)scanf("%d",a+i); for(left=0,right=5-1;left<right;++left,--right) i = a[left] , a[left] = a[right] ,a[right] = i; for(i=0;i<5;++i)printf("%d\n",a[i]); } (2) #include<stdio.h> #include<stdlib.h> int compare(const void*a,const void*b){ int c=*(int*)a,d=*(int*)b; return (c>d) - (c<d); } int main(){ int a[4]={-1,-1,-1,-1}; while(scanf("%d",a),*a != 0)qsort(a,sizeof a/sizeof*a,sizeof*a,compare); printf("%d\n",a[1]); }
389 名前:386 [2008/10/16(木) 17:00:07 ] すいません! osなんですが、Linuxとunix系OSを間違えて書いてました…… 正しくは OS:unix系のOSかwindowsです 申し訳ありません……
390 名前:デフォルトの名無しさん [2008/10/16(木) 18:45:15 ] [1] 授業単元: [2] 問題文(含コード&リンク): 以下のようなデータが大量に格納されているファイルがある. [ダウンロード www.vox.tutkie.tut.ac.jp/~katurada/test.list ] このファイルを読み込み,数値(キー)と英単語(データ)をセットにして 1データとして2分木へ格納し、数値(キー)にある値を指定して検索を行えば、 その数値(キー)に対応する英単語(データ)を検索できるプログラムを作成せよ。 ふたつめ 上記で使用したtest.list を読み込み,数値(キー)と英単語(データ)をセットにして 1データとしてリストへ格納し、数値(キー)にある値を指定して検索を行えば、 その数値(キー)に対応する英単語(データ)を検索できるプログラムを作成せよ。 そして、上記の木構造による実装との検索時間を比較せよ。 [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン:gcc [3.3] 言語:C [4] 期限:[2008年10月19日24:00まで]
391 名前:390 [2008/10/16(木) 18:46:22 ] 5] その他の制限: 1. 格納できるデータ量は(メモリの許す限り)上限はない. 2. 対応する英単語が見付からない場合は、その旨を表示すること。 3. データは,「数値,英単語\n」(\nは改行)で定義されるものとする. 4. データが格納されたファイルは、プログラムの引数で指定できるようにせよ。 5. データは2分木に格納せよ。 6. 数値(キー)に重複はない。 7. 数値(キー)は8桁以内である。もしファイルに9桁以上の数値が入っていた場合はエラーを出力して終了せよ。 8. 数値(キー)に数字以外の文字(アルファベットなど)が含まれていた場合は,エラーを出力して終了せよ. 9. 検索時の入力にも9桁以上の数値や数字以外の文字が入力された場合はエラーを出力して終了せよ. 10. 英単語は25文字以内である。もしファイルに25文字以上の英単語が入っていた場合はエラーを出力して終了せよ。 ふたつめ # リストによる実装において、データの挿入は数値(キー)によるソートは行わず、単純にファイルに出現した順番にリストに追加していって下さい。 # リストによる実装での検索も、単純にリストの先頭から比較していくような単純なアプローチで結構です。 # 1回の検索では検索時間の差がないでしょうから、10000回くらい繰り返して下さい。なお、test.list のデータ数は130万個あります。 よろしくお願いします。
392 名前:374 mailto:sage [2008/10/16(木) 18:46:38 ] >>384 ありがとうございます ヒントにしてもうちょい考えてみます
393 名前:デフォルトの名無しさん [2008/10/16(木) 21:26:24 ] >>373 ありがとうございました。 これを参考に、自分なりにもう少し頑張ってみます
394 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 22:02:18 ] >>380 bmpのフォーマットは?
395 名前:デフォルトの名無しさん mailto:sage [2008/10/16(木) 23:06:39 ] [1] 授業単元: C言語 [2] 問題文(含コード&リンク): UDPサーバkansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7791.txt UDPクライアントkansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7792.txt 問題文(2問あります)kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7793.txt [3] 環境 [3.1] OS:WindowsXP [3.2] Visual stdio2005 [3.3] 言語:C [4] 期限:10月17日午後13:00まで [5] その他の制限:特になし よろしくお願いします
396 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 00:43:47 ] [1] 授業単元:プログラミング技術 [2] 問題:30000以下の数字を入力して、「○時間、○分、○秒」と出力するプログラムを作りなさい。 <時間を分にして、分は秒にして、秒は分の答えの余り> [3] 環境 [3.1] OS:Windows XP [3.2] Ultla C [3.3] 言語:C [4] 期限 特にありません よろしくお願いします。
397 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 01:17:09 ] >>396 #include <stdio.h> int main() { int x; scanf("%d", &x); printf("%2d時間%02d分%02d秒", x / 3600, x % 3600 / 60 , x % 3600 % 60); return 0; }
398 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 01:28:59 ] [1] 授業単元:C [2] 問題:n=1 4973/n*2で始まり、4973/n*2の計算の答えが1になるまでnを増やしていき 1になったところで今まで出した数字を全部足した答えを出すプログラム。 少数は切り捨て。 [3] 環境 [3.1] OS:Windows XP [3.2] コンパイラ名とバージョン:gcc [3.3] 言語:C [4] 期限 [10/17/07:00まで] 2 4 8 4096 (4973/n*2)+(4973/n*2)+(4973/n*2)+・・・・(4973/n*2) 2486 + 1243 + 621 +・・・・ 1 =4965 手計算だと最後のnは2048になって答えが4965になったのですが。 プログラムについてはさっぱりなので助けてください。。。
399 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 01:36:21 ] >>398 あ、n*2じゃなくて、2^nです。
400 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 01:41:42 ] こんなでいい? #include<stdio.h> int main(){ int sum,ex; for(sum=0,ex=2; 4973/ex >= 1; ex*=2){ sum += 4973/ex; } printf("%d\n",sum); return 0; }
401 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 01:50:56 ] include <stdio.h> int main() { int n, sum = 0; for (n = 1; 4973 / (1 << (n - 1)) != 1; ++n) { sum += 4973 / (1 << (n - 1)); } sum += 1; printf("%d : %d", n, sum); return 0; }
402 名前:401 mailto:sage [2008/10/17(金) 01:51:44 ] すいません間違えました
403 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 01:54:33 ] そんなすっきりなプログラムが!! ありがとうございます!!
404 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 01:56:50 ] >>402 ぇ?答えの4956もでましたけど・・・
405 名前:404 mailto:sage [2008/10/17(金) 01:58:31 ] あ、>>400 の方と>>401 の方を読み間違えた自分が恥ずかしい…
406 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 03:26:13 ] >>392 if( tmp * (a * small_x[i] - small_y[i]) <= 0.0 ) ↓ if( (tmp *= (a * small_x[i] - small_y[i])) <= 0.0 ) な気がする
407 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 04:04:02 ] >>380 ttp://kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7794.txt 全BMPフォーマット対応は面倒だから、条件付き、 良く読んで理解して使用のこと
408 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 04:51:51 ] >>407 ん〜〜〜
409 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 07:23:29 ] [1]授業 c [2] 問題: 1単語を入力し、その単語のスペルを判定する。その判定を Ctrl-D を入力するまで続ける。判定は、ファイル ``eng.txt'' にその単語が存在する場合に限り、スペルが正しいと判定する。 [3] 環境 [3.1] OS:linux [3.2] gcc [3.3] 言語:C [4] 期限 10/19 16:00 関数は何を使ってもいいです。 何日も考えたのですがぜんぜんわかりませんでした。 どなたかお願いします
410 名前:395 mailto:sage [2008/10/17(金) 07:26:17 ] すみません 問題文2問あるといっておいて4問ありました B1とB2のみで構いません 多少遅れても大丈夫なので引き続きよろしくお願いいたします
411 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 07:40:04 ] >>395 UDPサーバ:kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7797.txt UDPクライアント:kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7798.txt
412 名前:410 mailto:sage [2008/10/17(金) 07:48:20 ] >>410 ちょっと訂正 UDPサーバ:kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7799.txt UDPクライアント:kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7798.txt
413 名前:396 mailto:sage [2008/10/17(金) 07:59:31 ] >>397 ありがとうございました
414 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 08:29:04 ] 400と401の両方とも、条件部とループ内部で同じ計算をしてるのが無駄
415 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 10:31:23 ] >>412 ありがとうございました
416 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 11:13:35 ] >>411 そんなの最適化されるんじゃないの?
417 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 11:15:12 ] >>411 じゃなくて>>414
418 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 15:40:59 ] >>409 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7801.c
419 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 15:51:15 ] [1]C言語実習 [2]問題文 以下のコードは、2つのプログラム(同一動作)のコードを まとめたものです。(各ソースにおいて、行の順番は変えていません) このコードを2つのプログラムに分解して、それぞれコンパイルが 通り、同一の動作をするようにして下さい。 また処理内容についても簡単にコメントして下さい。 コード kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7802.c[3] Linux/Gnu-C4.0/C [4]無制限だそうです。難問だそうです。よろしくお願い致します。
420 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 15:55:13 ] >>416 よく知らないんだが、どのコンパイラでどのオプションつけるとこれが最適化されるの?
421 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 16:14:39 ] >>419 #include <stdio.h> int is_prime(int p){ int i; if(p<=1) return 0; if((p==2)||(p==3)) return 1; if((p%2==0)||(p%3==0)) return 0; for(i=3;i*i<=p;i+=2) if(p % i==0) return 0; return 1; } int main(void){ int i,c=0; for(i=1;i<=1000000;i++){ if(is_prime(i)) c++; if(i%100==0) printf("%d %d\n",i,c); } return 0; } 素数の個数を求めるプログラム 残りはエラトステネスの篩だな
422 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 17:57:37 ] >>420 僕もよく知らない、ってかよく知らないのに突っ込まないでください>< 基本的に、共通部分式の削除が行われるんじゃないですか?
423 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 18:25:25 ] 418さんありがとうございました 感謝です
424 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 20:01:06 ] [1] 授業単元: プログラミング実習2 [2] 問題文(含コード&リンク): BMI値を判定するプログラムを作成する 入力:身長t(m),体重w(kg) 出力:判定結果{やせ,標準,肥満} 身長をt(m),体重をw(kg)としたとき, BMI=w/tの二乗 BMI値が18.5未満⇒やせ BMI値が18.5以上かつ25.0未満⇒標準 BMI値が25.0以上⇒肥満 #include <stdio.h> int main(void) { float t, w; printf("t = "); scanf("%f", &t); printf("w = "); scanf("%f", &w); ????????????????????????????????←この部分が解りません。 } [3] 環境 Visual C++ [3.1] OS:Windows [3.2] コンパイラ名とバージョン: C++コンパイラ,リンカ [3.3] 言語: C言語 [4] 期限: 2008年10月20日(月)までお願いします。 [5] その他の制限: main関数,文末記号,エスケープシーケンス,printf関数,条件分岐(if文,if-else文)は習いました。 お願い致します。
425 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 20:06:21 ] int main(void) { float t, w, bmi; printf("t = "); scanf("%f", &t); printf("w = "); scanf("%f", &w); bmi = w / t / t; if (bmi < 18.5) printf("やせ\n"); else if (bmi < 25.0) printf("標準\n"); else printf("肥満\n"); return 0; }
426 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 20:55:26 ] [1] 授業単元:プログラミング [2] 問題文(含コード&リンク): kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7788.txt [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン:gcc [3.3] 言語:C言語 [4] 期限: 10/18 すいません。なかなかうまくいきませんよろしくお願いします
427 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 21:03:49 ] いくつかレスをもらっても何も進歩してないことにがっかりした
428 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 21:29:19 ] >>426 ちゃんとみてないけど、 if(*(s+i)==' '){ の行を if(*(s+i)==' ' || *(s+i)=='?' || *(s+i)=='!' …){ ってやっていけばいいんじゃね
429 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 21:52:12 ] ということを>>336-337 が。
430 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 22:13:26 ] >>426 #include<stdio.h> #include<string.h> #define MAX 256 int main(void){ int len=0, max=0, moji; char s[MAX+1], l[MAX+1]=""; while((moji=getchar())!=EOF){ if(strchr(" \t\n?!.,()", moji) || len>=MAX){ if(len>max){ strcpy(l, s); max=len; } len=0; }else{ s[len++]=moji; s[len]='\0'; } } printf("The longest word is \"%s\"\n", l); return 0; }
431 名前:デフォルトの名無しさん mailto:sage [2008/10/17(金) 23:41:45 ] 個人的にはif elseよりswitchの方が好きだ。
432 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 00:09:20 ] 個人的にはふさわしい方を使うのが好きだ。
433 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 00:15:54 ] >>390 二分木の方だけやってみた kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7805.txt
434 名前:デフォルトの名無しさん [2008/10/18(土) 10:37:12 ] [1] 授業単元:先輩の課題 [2] 問題文(含コード&リンク): 5.3 121.1 123.0 56.8 4.6 21.4 9.2 6.7 ・ ・ ・ みたいなtxtファイルがあるとします。 これを行ごとに呼んで double data[4]に順番にいれて、関数にわたす。 そして次の行をまた同じ配列data[4]にいれて、関数に渡すっていう処理するプログラムを書け [3] 環境 [3.1] OS: Windows XP [3.2] コンパイラ名とバージョン: Visual studio 2008 [3.3] 言語: C [4] 期限: 今日 [5] その他の制限: なし
435 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:18:31 ] >>434 意味不明 文章を見直せ
436 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:25:05 ] [1] 授業単元:先輩の課題 [2] 問題文(含コード&リンク): 5.3 121.1 123.0 56.8 4.6 21.4 9.2 6.7 ・ ・ ・ みたいなtxtファイルがあるとします。 これを行ごとに呼んで double data[4]に順番にいれて、関数にわたす。 そして次の行をまた同じ配列data[4]にいれて、関数に渡すっていう処理を ファイルの終わりまで繰り返すプログラムを書け [3] 環境 [3.1] OS: Windows XP [3.2] コンパイラ名とバージョン: Visual studio 2008 [3.3] 言語: C [4] 期限: 今日 [5] その他の制限: なし これでわかりますかね。すいません
437 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:33:08 ] >>436 #include <stdlib.h> #include <stdio.h> void f(double *d) { } int main(int argc, char *argv[]) { FILE *fp; double data[4]; if (argc != 2) return 1; if (!(fp = fopen(argv[1], "r"))) { return 1; } while (fscanf(fp, " %lf %lf %lf %lf", &data[0], &data[1], &data[2], &data[3]) == 4) { f(data); } return 0; }
438 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:34:52 ] >>437 ありがとうございます。 列が100ぐらいあるときは%lfを百個打つのはめんどくさいんですが・・・ なんとかなりませんか?
439 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:44:10 ] >>438 Ctrl+Vを99回押すだけだろ
440 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:44:49 ] >>439 そうなんですが・・・ソースが汚いのかなぁとおもいまして・・・
441 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:45:04 ] 9回コピーして10個まとめたのをあと9回コピー
442 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:51:09 ] >>440 見た目の問題かい ループで回したらいいじゃん while (!feof(fp)) { for (i = 0; i < 100; i++) { if (fscanf(fp, "%lf", &data[i]) != 1) { printf("error"); return 0; } } f(data); }
443 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 12:58:08 ] >>442 どうもありがとうございました
444 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 13:01:02 ] もうひとつ質問させていただきます。 入力ファイルの途中に 5.3 121.1 123.0 56.8 4.6 21.4 9.2 6.7 52.3 121.1 123.0 56.8 45.3 121.1 123.0 56.8 4.6 21.4 9.2 6.7 改行で空いてる行があったとしても正常に動きますか?ためしたところ問題ないようにみえましたが・・・
445 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 13:02:07 ] >>444 正常の定義は? エラーを出して止まるのが正常なのか 書式を無視するのが正常なのか
446 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 13:07:44 ] >>445 空白の行を無視して次の行から配列に代入する処理というのが正常です
447 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 19:03:24 ] [1]授業 c言語 [2] 問題:kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7807.txt [3] 環境 [3.1] OS:linux [3.2] gcc [3.3] 言語:C [4] 期限 10/20
448 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 19:56:05 ] &s[i].id s[i].name &s[i].score[j]
449 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 22:10:12 ] [1] 授業単元:プログラミング基礎 [2] 問題文 体重と身長をキーボードから入力し、BMIを計算して出力するプログラムを書け。 BMIの計算はユーザ定義の関数を用いて行い、データの型にはdoubleを用いよ。 ただし、BMIの計算式は以下の通り。 BMI=体重(kg)/身長(m)^2 例:65kg/(1.70m * 1.70m) =22.49 [3] 環境 [3.1] OS:Windows XP [3.2] コンパイラ名とバージョン: gcc [3.3] 言語: C [4] 期限: 2008年10月21日まで [5] その他の制限: かなり初歩の段階みたいです。 よろしくお願いします。
450 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 22:27:55 ] >>449 >>424-425
451 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 22:31:24 ] >>449 #include<stdio.h> double bmi(double weight, double height) { return weight / (height * height); } int main() { double weight, height; printf("体重(kg)?"); scanf("%lf", &weight); printf("身長(m)?"); scanf("%lf", &height); printf("BMI=%g\n", bmi(weight, height)); return 0; }
452 名前:デフォルトの名無しさん mailto:sage [2008/10/18(土) 22:56:20 ] >>450 >>451 すいません。説明不足でしたがelseやifなんかはまだ習ってないくらい初歩なので >>424-425 はよくわからないんです。 お早いレスで助かりました。ありがとうございます。
453 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 02:08:14 ] >>425 こんなに早くやって下さり、本当に有難う御座いました。 助かりました。
454 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 05:04:55 ] >>453 elseやifについてどう思うかを>>452 に伝えてやってくれまいか
455 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 13:54:08 ] [1] 授業単元:プログラミング [2] 問題文: "A>B"と入力すると"AはBより大きい"のように、不等式を文章に変換するプログラムを作成せよ。また、入力データと実行結果は以下の通りとし、変換された文章をテキストファイルに順番に出力すること。 実行結果 データ1:A>B データ2:B<C データ3:A<C ○○○.txtに出力しました ○○○.txt AはBより大きい BはCより小さい AはCより小さい [3] 環境 [3.1] OS:windowsXP [3.2] コンパイラ名とバージョン:bcc [3.3] 言語:C [4] 期限:10/21 [5] その他の制限:可能な限り初歩的なものでお願いします
456 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 14:38:08 ] #include <stdio.h> #include <stdlib.h> int main(int argc, char *argv[]) { FILE *fpr, *fpw; char s1[1000], s2[1000], c; if (argc != 3) { fprintf(stderr, "引数にこでたのむ\n"); return 1; } if (!(fpr = fopen(argv[1], "r"))) {fprintf(stderr, "ファイルが\n"); return 1; } if (!(fpw = fopen(argv[2], "w"))) {fprintf(stderr, "ファイルが\n"); return 1; } while (fscanf(fpr, " %[^<> ] %c%s", s1, &c, s2) == 3) { switch (c) { case '<': fprintf(fpw,"%sは%sより小さい\n", s1, s2); break; case '>': fprintf(fpw,"%sは%sより大きい\n", s1, s2); break; default: fprintf(stderr, "なかみが\n"); return 1; } } fclose(fpr); fclose(fpw); return 0; }
457 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 15:42:56 ] [1]授業 c言語 [2] 問題: kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7807.txt [3] 環境 3.1 OS:linux 3.2 gcc 3.3 言語:C [4] 期限 10/20 すいません、よろしくお願いします。
458 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 15:48:02 ] >>447 >>448
459 名前:デフォルトの名無しさん [2008/10/19(日) 16:04:58 ] >>457 まず、リスト@はmain関数の外で定義な。中でもいいけど、個人的には外の方が分かりやすい。 で、○○○は上から順に &s[i].id s[i].name &s[i].score[j] あんまり偉そうなこといいたくないが、これって構造体の基本問題だろ?? できるだけ自分で解けるようにしないと後々、辛い目にあうぞ。
460 名前:457 mailto:sage [2008/10/19(日) 17:07:53 ] >>459 ウザいです。 偉そうな口を聞いて欲しくないです。
461 名前:デフォルトの名無しさん [2008/10/19(日) 17:20:54 ] >>460 本当のことだろーが 構造体の基礎の基礎も出来てないやつが喚くな餓鬼め
462 名前:457 mailto:sage [2008/10/19(日) 17:23:18 ] >>461 スレ違いです。出て行ってください。
463 名前:457 mailto:sage [2008/10/19(日) 17:25:13 ] そういうのは止めてください >>458 どうもすいませんでした >>459 ありがとうございます
464 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 18:22:51 ] >>457 >>1 > なりすましを防ぐため、トリップを使ってください。
465 名前:デフォルトの名無しさん mailto:sage [2008/10/19(日) 19:44:19 ] ワロタ
466 名前: ◆iTaRIJflUs mailto:sage [2008/10/20(月) 00:09:33 ] [1] 授業単元:C言語プログラミング [2] 問題文 <その1> 以下のようなプログラムを作成しなさい. 2×10の2次元配列を定義し、1行目の配列([0][0〜9])に1から10までの数字を格 納し、2行目の配列([1][0〜9])に2の倍数を2から20まで格納し、配列に格納した 数字を画面出力するプログラム。 <その2> 以下のようなプログラムを作りなさい 10人の学生の成績が以下のようになっている。 int score[]={90,28,35,80,72,55,76,90,96,42} このとき、0から9までの学生の偏差値を計算せよ。 [3] 環境 [3.1] OS:Windows XP [3.2] コンパイラ名とバージョン: gcc [3.3] 言語: C [4] 期限: 2008年10月21日朝9時まで [5] その他の制限: まだまだ初歩の段階です。 どなたかお願いします。
467 名前:デフォルトの名無しさん mailto:sage [2008/10/20(月) 01:52:12 ] >>466 int num[2][10]; int i, j; for( i = 0; i < 2; i++ ) { for( j = 0; j < 10; j++ ) { num[i][j] = (j + 1) * (i + 1); /* (1〜10) × ( 1 or 2) */ printf( "%2d ", num[i][j]); } printf("\n"); }
468 名前:デフォルトの名無しさん mailto:sage [2008/10/20(月) 02:14:52 ] >>466 その2 #include <stdio.h> #include <math.h> int main(void) { int score[]={90, 28, 35, 80, 72, 55, 76, 90, 96, 42}; int i, n = sizeof(score) / sizeof(score[0]); double sum = 0., sqsum = 0., mean; for (i = 0; i < n; i++) { sum += score[i]; sqsum += score[i] * score[i]; } mean = sum / n; printf("標準偏差 = %f\n", sqrt(fabs(sqsum / n - mean * mean))); return 0; }
469 名前:デフォルトの名無しさん mailto:sage [2008/10/20(月) 08:39:37 ] [1] 授業単元:プログラミング [2] 問題文:x=1y=2 が関数swapをもちいてx=2、y=1となる。関数swapを呼び出す前後のx,yのアドレスを表示し、アドレスが渡されていることをしめせ。 [3] 環境 [3.1] OS:windowsXP [3.2] コンパイラ名とバージョン:visual2005 c [3.3] 言語:C [4] 期限:10/23 お願いします