1 名前:デフォルトの名無しさん [2010/05/26(水) 07:45:28 BE:94671825-S★(522522)] あなたが解けない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++の宿題片付けます 135代目 pc12.2ch.net/test/read.cgi/tech/1269438098/
331 名前:デフォルトの名無しさん mailto:sage [2010/06/05(土) 22:56:11 ] >>329 ideone.com/PMcBO 逆ポーランド 電卓とかでググってみてくれ
332 名前:329 [2010/06/05(土) 22:58:00 ] >>331 そんな難しいのじゃなくていいです・・ とりあえずwhileとか使って 数字入力 演算子入力 数字入力・・・・=答え みたいなのが作りたい。
333 名前:デフォルトの名無しさん [2010/06/05(土) 23:51:35 ] >>258 です。ポインタを用いないバージョンもできないでしょうか。
334 名前:デフォルトの名無しさん mailto:sage [2010/06/05(土) 23:55:00 ] >>332 こんなんでどう? codepad.org/b68KtrqB
335 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 00:04:36 ] scanf()はエラーも返すんだよね。
336 名前: ◆/91kCCQXBo mailto:sage [2010/06/06(日) 00:14:15 ] #include<stdio.h> int main(void){ int a=0, b=0, plus=1; char buf[80]; while(buf[0] != '='){ // fgets(buf,100,stdin); gets(buf); if(buf[0] == '+'){ plus = 1; b = a; } else if(buf[0] == '-'){ plus = -1; b = a; } else sscanf(buf, "%d", &a); } b = b + plus * a; printf("ans=%d\n", b); } /* 3 - 6 = ans=-3 */
337 名前:デフォルトの名無しさん [2010/06/06(日) 01:34:19 ] こんなソフト作ってください(お代は払います)ってな感じのスレどっかにあったかなぁ? アイデアはあるけどオツムがないからどうしようもなく放置したまま早1年。 発注するから誰か受注して って頼みたいんだけど?
338 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 01:53:31 ] >>337 pc12.2ch.net/test/read.cgi/software/1251624598/l50 なんてどう?
339 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 02:09:42 ] サンクス
340 名前: ◆QZaw55cn4c mailto:sage [2010/06/06(日) 02:37:30 ] >>258 >>333 codepad.org/K6MwzaHX
341 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 10:39:09 ] >>333 #include <stdio.h> int main(void) { char a[256], b[256]; int i, j, flg = 0; printf("文字列を入力してください。"); scanf("%s", a); printf("検索文字列を入力してください。"); scanf("%s", b); printf("文字列「%s」は", b); for(i=0; a[i]; i++) { for(j=0; b[j]; j++) if(a[i+j]!=b[j]) break; if(b[j]=='\0') { if(flg++) printf(","); printf("%d文字目から%d文字目", i, i + j - 1); }} printf("%s\n", flg ? "に存在します" : "は存在しません"); return 0; }
342 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 10:45:21 ] >>333 折角書いたけど>>341 の方がスマートでくやしい #include <stdio.h> int main() { char str[256], search[256]; int strIdx = 0, searchIdx = 0, found = 0; printf("文字列を入力してください。\n"); scanf("%s", str); printf("検索文字列を入力してください。\n"); scanf("%s", search); while(str[strIdx]){ if(str[strIdx] == search[searchIdx]){ found = strIdx + 1; while(search[++searchIdx]){ if(str[++strIdx] != search[searchIdx]){ found = 0; break; } } if(found) break; } ++strIdx; } if(found == 0) printf("文字列「%s」は存在しません。\n",search); else printf("文字列「%s」は%d文字目から%d文字目に存在します。\n",search, (found - 2), (found - 2) + (searchIdx-1)); }
343 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 10:47:15 ] しかもバグ入りという...
344 名前: ◆QZaw55cn4c mailto:sage [2010/06/06(日) 12:03:14 ] >>329 ちゃんとつくると難しいです。たとえばこんな感じになります。 codepad.org/ODg132aP
345 名前:デフォルトの名無しさん [2010/06/06(日) 16:10:45 ] 何故>>330 はダメなのでしょうか? >>344 ちゃんとつくらなくても>>336 のプログラムの中身がすでに 理解できないんですが・・・>>336 より簡単にできないんですか? どんなプログラムも付け足せば何とかなるんですよね。 buf[]とstdin, fgetsなど全く意味がわかりません。 一応プログラム自体実行したら正しくいきます。 ただ宿題なので、今まで習ったことでやるしかないんです。 一応C言語です。
346 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:15:25 ] >>345 そういうのは最初に全部テンプレ使って言え
347 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:23:51 ] >>345 #include<stdio.h> int main(void){ int a,b = 0; char c=' '; while(c != '='){ scanf("%d",&a); scanf("%c",&c); if (c == '+')b += a; else b -= a; } } これでどうだ
348 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:25:40 ] >>345 ちがった #include<stdio.h> int main(void){ int a,b = 0; char c=' '; while(c != '='){ scanf("%d",&a); scanf("%c",&c); if (c == '+')b += a; else if(c == '-')b -= a; } printf("%d\n", b); } こうかな。
349 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:41:12 ] >>345 なぜダメかという理由を書くと 1.while(a != '=')となっている点。 aは数字だろ?演算子はcに入れたいんだろ?だからwhile(c!='=')が正しい。 2.if(c='-')となっている点。 =は代入。比較なら==を使う。たまに見かけるバグだな。 3.int a,b;となっていて、bを初期化していない点。 bに結果を入れたいのだろうが、最初に0で初期化していない。 初期化しないと値は不定。何が入ってるか分からないというわけ。 つまりコンパイラとしてはbに最初から0xCDCDCDCDを入れておいても仕様違反ではないというわけだ。 vc++のデバッグビルドならそうなる。 そこにプラスマイナスしても正しくならないよな。 4.else b-=a;となっている点。 これだと'='が来たときも引き算してしまう。だからese if(c=='-')にしないといけない。 5.whileに最初に入った時点でcは不定。 だから万が一cが'='だったらすぐ抜けてしまう。ここでは' 'を入れておけば絶対に問題が起きないのでおk。 現実問題として、滅多に起きないが、社会にでたらこれは立派なバグとして扱われるぞ。
350 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:42:02 ] こいつに理解させるのはまず無理だと思うけどな
351 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:53:45 ] 俺に聞けスレで諦めた一人ですな
352 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:55:49 ] >>348 12+12=0…
353 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 16:58:45 ] だからscanf()で文字を読むときは改行文字に気をつけろって言っただろ
354 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 17:01:25 ] int a=0 ,b=0; char c=0; scanf("%d%*c",&b); while(scanf("%c%*c",&c) && c != '='){ scanf("%d%*c",&a); if (c == '+')b += a; else if(c == '-') b -= a; else ; } printf("%d\n",b); それを修正してとなると↑のようになる(scanf削って縮めたいんだが、俺には限界)
355 名前:349 mailto:sage [2010/06/06(日) 17:03:34 ] ああ、ごめん。 実際に動かしてみたら色々問題がまだあるね scanf("%c", &c);は改行コードを拾ってしまうな。
356 名前:4 [2010/06/06(日) 18:52:56 ] >>350 >>351 ひどすぎワロタww 命かけて頑張ってんだよ、茶化さんで。
357 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 18:56:00 ] >>356 命がけ、というのであれば、それを見せてほしいですね。現状では伝わってこないんです。
358 名前:4 [2010/06/06(日) 18:58:23 ] >>354 優しすぎ、ありす。 まじで感謝してる。プログラミングの単位たぶん落とすと思うけど 2学期には間に合うようにするわ。
359 名前:デフォルトの名無しさん [2010/06/06(日) 19:02:36 ] 熟練のマである>>355 でもエラー出すC言語ってどんだけむずいんだよ。 もっと簡単で寛容なC言語はないんかね。
360 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 19:03:51 ] いろいろと突っ込みどころがあるな
361 名前: ◆QZaw55cn4c mailto:sage [2010/06/06(日) 19:44:23 ] >>359 ちょっと上の方でコテが散々やっつけられていたのを見ましたか? 簡単で寛容な、というのは期待しないほうがいいかと。
362 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 20:20:28 ] 宿題というか、既存のプログラムのバグ消しのお願いです AviUtlという画像編集・エンコソフトを使っているですが、 そのソフト用にNL-Means Filterというものが出ています。 ですがそのフィルターを使うとソフトがフリーズしてしまいます。なんとか解決できませんか? 症状としては、そのフィルターをオンにすると、AviUtlを終了しようとした時にフリーズします。 GPU支援を使う、計算モード3のときのみ起こります。お願い致します kishibe.dyndns.tv/index.php?%E3%83%95%E3%83%AA%E3%83%BC%E3%82%BD%E3%83%95%E3%83%88%2FNL-Means%20filter からダウンロードするとソースらしきものもついてきます
363 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 20:56:36 ] [1] 授業単元:プログラミング演習 [2] 問題文(含コード&リンク): kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/10650.txt [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン:gcc [3.3] 言語:C [4] 期限: 2010年6/8まで [5] その他の制限:なし 2問ありますが、よろしくお願いします。
364 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:06:03 ] >>363 <課題2> #include <stdio.h> #include <stdlib.h> int main(void) { int i, j, k, n; double *x, temp; scanf("%d", &n); x = malloc(n * sizeof(double)); for(i=0; i<n; i++) scanf("%lf", x + i); for(i=n-1; i; i=k) { for(j=k=0; j<i; j++) { if(x[j] > x[j+1]) { temp = x[j]; x[j] = x[j+1]; x[j+1] = temp; k = j; }}} for(i=0; i<n; i++) printf("%f\n", x[i]); free(x); return 0; }
365 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:30:33 ] >>363 <課題1> codepad.org/i9GSGdcP
366 名前: ◆QZaw55cn4c mailto:sage [2010/06/06(日) 21:36:06 ] >>363 codepad.org/XdsWKbxa codepad.org/qynZDN0h
367 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:44:36 ] ぐだぐだ言い訳されるのわかってても突っ込みたくなるなw
368 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:45:38 ] >>367 どうぞどうぞ突っ込んでくださいな。楽しみにしています。
369 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:48:51 ] 実数と整数の区別もつかないアホ ソート部分がクソ
370 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:55:59 ] >>363 です ありがとうございます
371 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:56:08 ] >>363 2番目の課題を訂正します。 codepad.org/qgboBPOZ >>369 普通のバブルソートですが、何か問題でも?
372 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 21:57:51 ] だからそれはバブルソートじゃないって言っただろw
373 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:02:21 ] >>372 あれ?私は en.wikipedia.org/wiki/Bubble_sort を参照したんですけれどもね。
374 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:09:35 ] それが言いたくてわざわざ効率の悪いほう使ったのかw
375 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:10:08 ] >>373 バブルソートは for(j=0;j<n-1;j++){ for (i = 0; i < n - 1; i++) { if (x[i] > x[i + 1]) { t = x[i]; x[i] = x[i + 1]; x[i + 1] = t; } } } だろ。わざわざdo{} while()にしても比較回数が減ることはない。
376 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:16:38 ] >>373 だから全部読めって前も言ったよな? Optimizing bubble sortのところで何でn := newn + 1ってなってると思ってるんだ?
377 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:17:08 ] >>375 そうですよね。>>375 であげていただいたやり方もバブルソートといいますよね。 でも >>372 はお気に召さないようなんですよ。 確かに日本語版 wiki やドイツ語 wiki では、幾分効率をあげたものが採用されているようですが、 どうオプティマイズしても計算オーダーはΟ(n^2) で変わらないのですけれども、>>372 は計算オーダーの概念がよくわかっていないらしい。 pc12.2ch.net/test/read.cgi/tech/1269438098/706 のように、ある一種のバブルソートの実装にこだわっているんです。
378 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:18:14 ] >>376 Optimizing のところでは、長さを縮めていますが、そうでない実装も、やっぱり bubble sort でしょう?
379 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:21:35 ] 計算オーダーが同じでも明らかに効率悪い方に拘る意味が分からんw
380 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:24:12 ] こだわっているんではなくて、計算効率がちょびっとよくなるか悪くなるかの差で、バブルソートとよんだりよばなかったりするのはおかしいといっているのです。 英語版 wiki にのっている実装もバブルソート、 >>375 のやりかたもバブルソートなんですよ。無論私のもバブルソート。
381 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:42:15 ] ん、バブルソートですね
382 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 22:48:20 ] 知識とコードのアンバランスさから見て、どっかの大学講師かな。 実務経験があるようには見えないし、頭堅いのにプライドだけは高いし。
383 名前: ◆QZaw55cn4c mailto:sage [2010/06/06(日) 23:20:44 ] >>382 今は助教というのですよ。現在の大学教員の序列を知らないところから見ると、高校生かな?
384 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:21:28 ] 高校生に負ける助教って・・・
385 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:29:08 ] どうりで高校生なら計算オーダーの話は理解できなくてもしかたありませんね。でも重要ですからよく勉強しておくように。
386 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:29:24 ] 日本語まともに読めないクズの分際で、 なんで自分より下しか想像できないんだろうw
387 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:31:46 ] バブルソートでも色々あるんですよ。ひとつのパターンだけ決め付けてこれはバブルソート、あれは違う、などと見識の狭いことをいってはいけません。 もっと広い感覚で物事を理解することです。
388 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:32:52 ] 実数と整数の区別もつかない盲が何言ってんだw
389 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:35:12 ] というか本当に助教なの?せいぜい院生くらいかと思ってたんだけど。 日本語の読めなさはやばいってレベルじゃねーだろw
390 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:35:43 ] 小さなミスはその都度修正すれば済むこと。でもバブルソートがなにかを理解していなければ、ヒープソート、シェルソート、クィックソート、マージソート その他いろいろなソートでもつまづきますよ。これらの理論では計算オーダーが重要ですからよく勉強しておくことです。
391 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:39:51 ] なんで相手がそれらのソートを知らないことになってんだよw
392 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:40:02 ] >>382 で講師だろうといっていたくせに、 >>389 で院生くらいだとおもっていた、 とは随分とおっしゃることがころころかわるのですね。日本語が読める読めないというより、日本語を使って思考できないのではないですか?
393 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:40:32 ] ちょ、同一人物認定されたw
394 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:40:43 ] >>391 計算オーダーを理解していないようですからね。
395 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:54:27 ] すいません、できたら>>362 お願い致します 流石に無理ですかね・・・
396 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:55:50 ] >>395 スレ違いな上に、金取るぞってレベルの話なんだがw
397 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:57:10 ] >>395 無理に決まってるだろw
398 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:57:21 ] やっぱり無理ですよねw じゃあだめもとで他当たってきます ありがとうございました
399 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:58:06 ] >>395 作者に直接言ってみれば もちろん、単にエラーが出るとだけ。 ttp://twitter.com/_kenkun
400 名前:デフォルトの名無しさん mailto:sage [2010/06/06(日) 23:59:34 ] 大体フィルタだろ? フィルタのソースはAviUtilの作者とは違うだろ。
401 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 00:00:30 ] >>399 いや、AviUtlに問題があるわけではなくて このフィルタに問題があるんですよね フィルタの作者はAviUtlの作者ではないんで・・ でももしかしたらAviUtl側でなんとかできるかもしれませんね ありがとうございます。
402 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 00:01:58 ] 関係ないフィルタの不具合を報告されても困るだろw
403 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 00:18:46 ] まぁここはご覧の通り高校生レベルの議論なんで・・
404 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 00:19:12 ] 高校生以下のおじさんもいるけどね
405 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 02:09:08 ] 高校生だったころに戻りたいな
406 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 04:04:49 ] 中学レベルの英語力すらない人が多いみたいだけどね
407 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 06:55:32 ] that's too mad.
408 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 12:38:44 ] >>395 せっかちだなぁ
409 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 19:02:23 ] >>406 んじゃ、そのあんたのレスを英語で頼む
410 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 19:09:19 ] all your base are belong to us
411 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 20:02:34 ] ポインタを使い1〜12までの数字を入力すると英語で月の名前が出力され、 そうでない場合はunknown month と出力されるプログラム作りで困ってます。 入力例 3 5 13 11 出力例 March May unknown month November ヒントでは、 char *month_name(int n)を書き入れる事 month_name(6)はJuneである事 static char *months[] = { "January","February","March", "April","May","June", "July","August","September", "October","November","December"}; を用いる事が書かれてます。 暇な人が居たらお願いします。
412 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 20:16:30 ] >>411 char *month_name(int n) { if (n < 1 || 12 < n) { return "unknown month"; } return months[n-1]; }
413 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 20:20:27 ] staticだから関数内にmonths[]置くんじゃないの?
414 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 20:24:16 ] じゃあそれで
415 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:12:44 ] 途中経過を…プログラミングは下手ですがっ #include <stdio.h> static char *months[] = { "January","February","March", "April","May","June", "July","August","September", "October","November","December"}; int main(void) { int n; char *month_name(int n) {if (n < 1 || 12 < n) { return "unknown month"; }return months[n-1]; } scanf("&lf",&n); printf("%s",*months); return(0); } これでやるとどんな数字入れても出力がJanuaryになってしまうのですが、 どこらへんを変えればいいでしょうか?
416 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:14:17 ] >>415 &lf ってなんだよ
417 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:15:40 ] scanf("%d", &n);
418 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:18:19 ] つーか関数内に関数置くな
419 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:21:46 ] >>415 なんという残念な使い方w
420 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:24:05 ] >>415 ideone.com/kEyhc scanf("&lf",&n); printf("%s",*months); の一連の流れをおかしいと思わなかったのはまずい
421 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:31:08 ] 残念な頭なのでmonth_nameの中に *months入れるのは思いつきませんでした…orz
422 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 21:37:19 ] >>421 慣れ、馴れ。数書くうちに体にしみこむ。
423 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 22:08:57 ] ケチ付けるわけではないけどif文はmainの中のほうがunkownのとき 関数を呼ばなくていいんじゃなかろうか。
424 名前:9 [2010/06/07(月) 22:11:27 ] 【質問テンプレ】 [1] 授業単元:C言語課題 [2] 問題文(含コード&リンク):2つの正の整数(aとb)の最大公約数をユークリッドの互除法を用いて表示するプログラムを作成せよ。ただし、0<b≦a≦32767とする。 ≪ユークリッドの互除法≫ ユークリッドの互除法による最大公約数(GREATEST COMMON DIVISOR:GCD)は、次のように求める。 @2数(aとb)の中で大きい値をl、小さい値をmとする。 Alをmで割り、あまりをrとする。 r=0ならば、mが最大公約数となる。 r≠0(0<r<m)ならばl←m、m←r として再びAの処理を行う。 [3] 環境 [3.1] OS:Windows [3.2] コンパイラ名とバージョン:main.c Visual Studio 2008 [3.3] 言語:C++ [4] 期限:2010年6月18日17:00まで [5] その他の制限:(まだ本当に初心者なので)do文やif文、for文まで習いました。 期限までは時間がありますが…宜しくお願いしますm(_ _)m
425 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 22:29:12 ] #include <iostream> int main() { int a, b, r; std::cin >> a >> b; while(r = a % b) a = b, b = r; std::cout << b; }
426 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 23:09:24 ] >>423 逆にその関数として、不正な値が渡された時はどういう挙動にしようか
427 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 23:10:21 ] for(i = 0 ; i < 5 ; i++){ printf("%d,", i ); } これで出力したら 1,2,3,4,5, みたいに最後にもカンマがついちゃうんでfor文の外側に printf("\b\n"); を付け加えたんだけどうまく最後のカンマが消えません その理由とどうすればいいのか教えてください
428 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 23:21:48 ] \bは書き込む位置が1文字分戻るだけだから スペースで上書きする必要がある printf("\b \n");
429 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 23:23:30 ] なるほど d
430 名前:デフォルトの名無しさん mailto:sage [2010/06/07(月) 23:25:03 ] >>427 端末側がバックスペースをサポートしていない、と思われる。 仕方がないから、 #include <stdio.h> #define N 5 int main() { int i; for (i = 1; i <= N - 1; i++) printf("%d, ", i); printf("%d\n", i); return 0; } でごまかすしかない。
431 名前:430 mailto:sage [2010/06/07(月) 23:29:20 ] >>428 そのような手があったんですね。これでうまくいきました。(cygwin) #include <stdio.h> #define N 5 int main() { int i; for (i = 0; i < N; i++) printf("%d, ", i); printf("\b\b \n"); return 0; }