1 名前:デフォルトの名無しさん [2008/10/30(木) 07:49:39 BE:113605834-PLT(24065)] あなたが解けない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++の宿題を片付けます 116代目 pc11.2ch.net/test/read.cgi/tech/1222813731/
45 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 13:46:19 ] これくらいのことができなきゃ、プログラムのためのプログラミング、実用的な計算? なんて無理。というか、プログラミングと数値計算は多少分野が異なる。
46 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 13:52:06 ] つってもある程度難しかったり、面倒だとだれもやらないくせにwwwwww
47 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 14:14:16 ] 計算に関しては、計算式を把握していれば、あとは標準ライブラリを用いるなり 多少拡張するなら、変数の扱い方をしっかりしていれば良い。
48 名前:デフォルトの名無しさん [2008/11/01(土) 16:44:27 ] [1] 授業単元:プログラムC [2] 問題文(含コード&リンク): gnuplotを呼び出し、 y=sin(x**2)のグラフを描くプログラム [3] 環境 [3.1] OS:Windows [3.2] コンパイラ名とバージョン:VC2005 [3.3] 言語:C [4] 期限: 11/5 よろしくお願いします。
49 名前:48 [2008/11/01(土) 16:59:46 ] 自己解決しました。
50 名前:48 mailto:sage [2008/11/01(土) 17:01:44 ] 止めてください どなたかお願いします
51 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 17:09:25 ] 奇数と偶数の和を求めます。関数を使わなかったら答えは出たのですが・・・。 どこが変なのか、お願いします。 #include<stdio.h> void calc(int x[],int num) { int kisu=0,gusu=0; int i; for(i=0;i<num;i++);{ if(x[i]%2==1) kisu+=x[i]; else gusu+=x[i]; } printf("奇数%d\n",kisu); printf("偶数%d\n",gusu); } int main(void) { int hai[10]={1,2,3,4,5,6,7,8,9,10}; //偶数30 奇数25 calc(hai,10); return 0; }
52 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 17:13:31 ] ((x[i]%2)==1)
53 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 17:15:03 ] for(i=0;i<num;i++);{ for(i=0;i<num;i++){
54 名前:51 mailto:sage [2008/11/01(土) 17:18:40 ] これは恥ずかしい・・・。ありがとうごさいます!
55 名前:デフォルトの名無しさん [2008/11/01(土) 19:00:21 ] 【質問テンプレ】 [1] 授業単元:計算機プログラミングII 「ポインタと文字列」 [2] 問題文(含コード&リンク):課題1 2つの任意の長さの文字列をポインタ変数pxとpyを使って入力し, pxとpyの文字列を結合した文字列を他のポインタ変数に記憶し,その 結果を出力するプログラムを作成せよ.ただし,ヘッダファイル string.hで定義されている関数およびsprintfを使用してはいけない. [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン:gcc [3.3] 言語:C [4] 期限:2008年11月6日10:30まで [5] その他の制限:ポインタの基礎を習い始めたところだと思います。 配列や文字列、for文、if文、関数ぐらいは簡単に習っています。
56 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 19:16:55 ] >>55 #include <stdio.h> #include <stdlib.h> int string_length(char *s) { int i = 0; while(*s++) i++; return i; } int main(int argc, char *argv[]) { char *px = argv[1]; char *py = argv[2]; int len_x = string_length(px); int len_y = string_length(py); int len = len_x + len_y; char *pz = malloc(len + 1); memcpy(pz, px, len_x); memcpy(pz + len_x, py, len_y); pz[len] = '\0'; puts(pz); free(pz); return 0; }
57 名前:お願いします [2008/11/01(土) 20:32:50 ] [1] 授業単元: アルゴリズムデータ構造2 [2] 問題文(含コード&リンク): 課題 (乱数とシミュレーション、分布に従った乱数) 設問1 0から100までの一様乱数を1000回発生させ、 その頻度分布を求めよ。 設問2 いわゆる成績(偏差値)の分布の例として平均 50、標準偏差10の正規分布乱数を1000回発生させ、その頻度分布を求めよ。 なお、頻度分布は次の10種類とする。 0点から10点まで、10点から20点まで、30点から40点まで、 50点から60点まで、70点から80点まで、80点から90点まで、 90点から100点まで、 設問3、設問1で求めたデータの平均と標準偏差を求めよ。 設問4、設問2で求めたデータの平均と標準偏差を求めよ。 設問5、設問1および設問2の頻度分布をヒストグラムとして表として 見やすく作成せよ。 [3] 環境 [3.1] OS: (Windows) [3.2] コンパイラ名とバージョン: すいません、コマンドプロンプトとしか・・ [3.3] 言語: (C言語) [4] 期限: 11月3日までで お願いします [5] その他の制限: (できるとこまででいいのでお願いします、制限は、乱数表記で) 問題は下に張ります
58 名前:お願いします [2008/11/01(土) 20:37:05 ] /* distran.c */ #include <stdio.h> #include <stdlib.h> #include <time.h> #include <math.h> float nrand(void) { return(float)rand()/RAND_MAX; /* 0.0 --- 1.0に正規化された乱数 */} float urand(float a,float b) { /*区間[a,b]の一様乱数*/ return a+(b-a)*nrand();} float nmrand(float mu,float sigma) { /*正規分布乱数*/ int i; float a; for(a=0,i=0;i<12;i++) a+=nrand(); return mu+sigma*(a-6.0);} float nmrand_n(float mu,float sigma,int n) { /*観測数nをもつ正規分布乱数No.2*/ int i; float a; for(a=0,i=0;i<n;i++) a+=nrand(); return mu+sigma*sqrt(12.0/n)*(a-n/2.0);} void main(void) /*観測数nを変化させたときの正規分布の乱数の分布の推移*/ { int i,j,k,f[10]; float mu=5.0,sigma=1.0; srand(time(NULL)); for(k=1;k<=32;k*=2) { for(i=0;i<10;i++) f[i]=0; for(i=0;i<1000;i++) f[(int)(nmrand_n(mu,sigma,k))]++; for(i=0;i<10;i++) { printf("\n %2d=%6.3f ",i+1,f[i]/1000.0); for(j=0;j<f[i]/20;j++)printf("*");} printf("\n");}} >57 この文の書き換えでよろしくお願いします^^
59 名前:デフォルトの名無しさん mailto:sage [2008/11/01(土) 22:34:10 ] >>57 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7909.c 1と3のみ。 > 頻度分布は次の10種類とする。 分からんので0〜9、10〜19、20〜29・・・区切りで。 発生させた乱数と、0〜100までそれぞれ出た回数を 最初に表示しているので、不要なら削除。
60 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 10:16:13 ] [1] 授業単元:プログラミング入門 [2] 問題文:ポインタと構造体を使って,各要素が文字列を保持するリスト構造を実装しなさい. ただし,保持している文字列がアルファベット順になるものとする.(例えば"America"→"Japan"→"UK"など) また,機能として,「保持している文字列を先頭から表示する」「新しい要素の挿入(挿入後に新しい要素もアルファベット順に並ぶ)」「指定した文字列を保持する要素の削除」を実装せよ. [3] 環境 [3.1] OS: Mac OS 10.5.5 [3.2] コンパイラ名とバージョン:分かりません [3.3] 言語: C [4] 期限: 11月3日まで [5] その他の制限:ポインタと構造体まで習いました。 お願いします。アルファベット順に並び替える、というのがどうすれば良いのか・・・
61 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 13:42:54 ] アルファベット順になる場所に挿入をすれば、結果的にソートされた状態になる。 挿入するデータと要素のデータを先頭から順番に比較していき、 挿入するデータの方が小さくなるような要素の前に、新しく要素を追加すればよい。 挿入するデータよりも大きいデータが無かったら末尾に追加。
62 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 14:01:17 ] >>60 空気を読まず、Windowsで作ったプログラムを登校してみる kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7912.txt [OS]Win Vista [コンパイラ]gcc 3.4.2(Mingw) 役に立たなかったらごめんなさい
63 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 16:59:16 ] [1] 授業単元: 信号処理 [2] 問題文(含コード&リンク): kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7914.txt の問題の続き @ 前回完成させたのプログラム以下のように変更させなさい。 プログラム→kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7915.c 変更箇所 data[cnt] < ave以下のとき 関数powを使って、分散の計算をして標準偏差を求めるように変更させなさい。 ※補足 出力したファイルはこのような感じになっていること peak.txt→ [67]3.214283 [84]2.4930390 [148]5.3485704 ・・・・ [38]3.4255342 [72]3.214283 [98]2.434924390・・・・ ・ ・ ・ [3] 環境 [3.1] OS: Windows XP [3.2] コンパイラ名とバージョン: gcc [3.3] 言語: C [4] 期限: 2008年11月4日午前8時まで [5] その他の制限: 特になし 何回やっても出力がうまくいきません。 それとdata.txtはDLするときDLKeyが必要になりますが お手数かけて申し訳ありません。 よろしくお願いします。
64 名前:help me [2008/11/02(日) 17:44:54 ] 授業単元:C言語 問題文(含コード&リンク):1から10までの任意の整数値を複数個(20〜30個)程度入力し、 入力した数値がそれぞれ何個ずつだったかを表示するプログラムを作成せよ。 ただし、入力は0を入力しない限り永遠に続くものとする。 なんか*を数字の横に出力 するみたいに表示するようです。 OS: (Linux) 言語:C 期限: ([2008年11月5日23:59まで] [5] その他の制限: あまりないようです。 なんか授業が難しくてついていけません。助けてください。
65 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 18:22:27 ] #include <stdio.h> int main() { char buf[1024]; int i,j, count[11] = {0}; while(fgets(buf, sizeof(buf), stdin)){ int n = atoi(buf); if(n == 0) break; if(n < 1 || n > 10) continue; count[n]++; } for(i=1; i<=10; i++){ printf("%02d ", i); for(j=0; j<count[i]; j++) putchar('*'); putchar('\n'); } return 0; }
66 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 20:29:49 ] >>63 問題文が意味不明すぎて答えが出ない。この際、仕様に間違いがあるのはスルー。 1.とりあえず、出力は、ソースから想像すると、 ・縦に全部ならべる(最大1024個)。横は1列。 ・各行は、入力データ(data[i])がave未満の時だけ出力する ・出力の各行は、[i]に続いて、data[i]の標準偏差 が1セットで、これをファイル終端まで繰り返すで、OK? +出力を横に並べるなら、横1列に並んでいる出力を、横方向にいくつか並べたいのだと推測されるが、いくつ並べるかが不明。 2.十分なメモリを確保のところ 読込先が2次元の配列になっているが、ソースは1次元。−> 2次元のほうはスルーでOK? +ファイル丸ごとメモリに展開する(らしい)仕様は、スルーでOK? それとも、配列サイズを最初に固定で取らずに何かしようとしてる? (の前に、入力データの範囲が規定されてないので、配列すら確保できない仕様だが・・・) mallocでメモリを確保したい、までは読めた。ただ、何に使うメモリを確保したいのかが書かれていないので、追記が必要です。 3.5行209921列のデータなら、1024で割り切れないのは明らかだが、 最後の1024個に満たないデータは、他と同じ処理でよい? データ自体も、データの個数が2で割り切れない+209920行しかないのだが・・ 行と列が違うのは、華麗にスルーできなかった。残念。 データ自体の不良でなければ、ここの処理の改造も必要です。 頭の中を整理するために書いたが、ここまで来て、やっと前回の@の部分の意味が分かった ・平均値は計算するだけ。ファイルには出力はしない。 ・データが(平均値+5*ρ)以上の場合だけ、計算した最大値をファイルに出力する ->元の問題文だと、どうみても、全データの最大値と変わらなかった気が・・ って、こんな事書いてる間に、プログラム何本か書けるんだが。。
67 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 20:58:47 ] [1] 授業単元:プログラミング [2] 問題文(含コード&リンク):kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7918.txt [3] 環境 [3.1] OS:Windows [3.2] コンパイラ名とバージョン:bcc [3.3] 言語:C [4] 期限:11月4日 [5] その他の制限:特になし 関数内でのポインタの使い方がさっぱりです、お願いします
68 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 21:03:05 ] mul(&n1, &n2); void mul(int *x,int *y){ int temp; temp = *x; *x = *x * *y; *y = temp/*y; }
69 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 21:03:29 ] >>67 #include<stdio.h> void mul(int *x,int *y); void main(){ int n1=10; int n2=5; printf("変数n1の値は%dです。\n",n1); printf("変数n2の値は%dです。\n",n2); printf("変数n1と変数n2の積をn1に、商をn2に入れます。\n"); mul(&n1,&n2); printf("変数n1の値は%dです。\n",n1); printf("変数n2の値は%dです。\n",n2); } void mul(int *x,int *y){ int temp; temp = *x; *x *= *y; *y = temp/(*y); }
70 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 21:30:10 ] >>68 >>69 助かりました、ありがとうございます
71 名前:60 mailto:sage [2008/11/02(日) 23:33:35 ] >>61 ,62さん ありがとうございます。strcmpで比較して正負が変わる位置に挿入すれば良い、 というのは分かったので、テキストのサンプルをコピペしつつ自分で書いてみたのですが、実行するとBus errorになってしまいます。ちょっと見ていただけないでしょうか? kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7919.txt InsertFruitsの中でprevを挿入したい要素の一つ前を指すポインタに、ptrを一つ後を指すポインタにして、そこからポインタをつなぎ変えて挿入をさせようとしてるのですが・・・ また 1.c:67: error: incompatible type for argument 1 of ‘InitList’ 1.c:69: error: incompatible type for argument 1 of ‘InsertFruits’ 1.c:70: error: incompatible type for argument 1 of ‘InsertFruits’ 1.c:71: error: incompatible type for argument 1 of ‘InsertFruits’ 1.c:74: error: incompatible type for argument 1 of ‘PrintList’ とも出てしまいます。これはどういうことなのでしょうか? 長くなってしまいましたが、よろしくお願いします・・・
72 名前:デフォルトの名無しさん mailto:sage [2008/11/02(日) 23:46:15 ] >>71 newて変数名は使えないよ。 67からのエラーは引数の渡し方が間違ってるって事。もちっとポインタ渡しについて復習してみそ。
73 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 00:00:01 ] c だから使えるだろう
74 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 00:05:31 ] ぐはそうだっけ?すまん。。。
75 名前:デフォルトの名無しさん [2008/11/03(月) 00:09:20 ] [1] 授業単元:ループ [2] 問題文(含コード&リンク):y=x*xの座標を*でプロットするプログラムを作ります。 縦をy軸とみなし、範囲は-5<=x<=5とします。使うのはループとputcharで、計算していいのは、 x*xだけ(y=x*xを変形してはいけない)です。 [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン:gcc [3.3] 言語: C [4] 期限:11月3日 [5] その他の制限:使うのはループとputchar よろしくお願いします。
76 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 00:27:23 ] >>71 ポインタが欲しいところに中身を渡してる。 くだものよりも、67行目〜74行目の*が、いらない子。 あ、くだものは一覧だったw といっても、InitList()に渡す前に、listの初期化必要でない? どこも指してないのに、そこのアドレスを使って何かを入れようとしても、 だめだと思います。 あ、配列の使い方だ。これを覚えようw
77 名前:60=71 mailto:sage [2008/11/03(月) 00:44:50 ] すみません、main関数の中身が間違ってました。 int main(void) { List list; InitList(&list); InsertFruits(&list, "orange"); InsertFruits(&list, "grape"); InsertFruits(&list, "apple"); puts("くだものいちらん"); PrintList(&list); return(0); } こうでした。 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7920.txt エラーは出なくなったのですが、Bus errorはやはり出ます。 InsertFruitsの中身がおかしいのだと思うのですが、どなたか助言をお願いします。。
78 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 00:52:12 ] >>75 #include <stdio.h> int main(void){ int x,y; for(y=25;y>=0;y--){ for(x=-5;x<=5;x++){ if(y==(x*x)) {putchar('*');} else {putchar(' ');} } putchar('\n'); } return 0; } x,yともにintだけどこれでいーの?
79 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 01:05:20 ] >>77 callocのあたりじゃないかと予言をして俺は寝る。限界だ
80 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 01:08:55 ] >>77 InitList()で、list->headまたはlist->tailのnextメンバをNULLにしておくなどあるべきだと思う。 InsertFruits()のFruits型へのポインタ変数newが明らかに無効なポインタだと思う。 while(strcmp()) {}で、ptr = ptr->nextとかあるが、ptrが例えばNULLのときどうするのか。 List型のtailメンバは使わないのか。
81 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 01:13:20 ] >>77 InsertFruits()でataraにallocしてないのでは? Fruits *atara; atara = (Fruits*)calloc( 1, sizeof(Fruits) );
82 名前:デフォルトの名無しさん [2008/11/03(月) 01:27:34 ] <<78 ちなみにifを使わないとしたら、どうなるでしょうか。
83 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 01:34:45 ] >>82 三項演算子使うぐらいしか思いつかん if(y==(x*x)) {putchar('*');} else {putchar(' ');} のとこを y==(x*x) ? putchar('*') : putchar(' '); にするとか。意味が感じられんが つーかなんでそんな偏屈じみた制約がついてるんだ
84 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 01:52:33 ] ふふふ、switchがあるぜよ?
85 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 01:55:04 ] >>77 さん kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7921.txt 試してみてください。 修正箇所はソースにコメントで記載してあります。
86 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 02:10:56 ] >>85 です コメント忘れましたが、PrintList()のwhileの中身の順番を入れ替えてました
87 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 02:12:34 ] >>77 =76 でおくれた! とりあえず途中まで書いた。直してるうちに、原型がなくなったとかは内緒。 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7922.txt 登録、表示まで実装。 ごめん、76で配列っていうのは、ただの勘違いw 制約条件のリスト構造忘れてたorz
88 名前:76=87=88 mailto:sage [2008/11/03(月) 02:25:58 ] >>77 もう一個。元のソースをいじるなら。 メモリの実体を確保せずにポインタを渡しても・・・ が、どこかでおきています。 【対策する所】 List list; //ここに何か。 InitList(&list); 【原因】、 /*headとtail初期化*/ void InitList (List *list) { list->head = list->tail = AllocFruits(); } で、listがどこもポイントしていないのに、 list->head、list->tailに値を代入していること。
89 名前:76=87=88=89 mailto:sage [2008/11/03(月) 02:29:16 ] うあ、いかん。読み違えた。 おとといから寝てないの、ひびいとるな・・・ 88は忘れて下さいorz
90 名前:デフォルトの名無しさん [2008/11/03(月) 03:27:32 ] [1] 授業単元:グラフの利用、データの可視化 [2] 問題文: @: 電気双極子の作る静電ポテンシャルは φ=(q/4πε){1/(x^2+y^2+(z-d/2)^2)^(1/2)-1/(x^2+y^2+(z+d/2)^2)^(1/2)} で与えられる。ここで、正負の電荷は、(0,0,5),(0,0,-5)に存在するとしたとき、つまりd=10のときのポテンシャルの概形を描け。ただし、q/4πε=1とせよ。 また、y=0として、x-z平面におけるポテンシャルのみを書けば良い。 図示する範囲は、xは-20と20の間、zは-40と40の間とし、その範囲を各々20等分、40等分して、21×41のデータとして入力せよ。 A: @と同様に+qの電荷が(0,0,5)、(0,0,-5)に、-2qの電荷が(0,0,0)に存在するとしたときのポテンシャルの概形を描け。 [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン:gcc [3.3] 言語:C [4] 期限:2008年11月4日16:00まで [5] その他の制限: 問題@だけでもいいのでお願いします。
91 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 03:43:36 ] gccでグラフ書くってgnuplotとかかな
92 名前:87=92 mailto:sage [2008/11/03(月) 04:23:40 ] >>77 削除部分も実装。参考程度に。 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7923.txt >>91 なにかちがうきがする・・
93 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 04:33:39 ] グラフィカルにプッロトするのもあるけど、単に * で表すとか。
94 名前:=92 mailto:sage [2008/11/03(月) 05:27:07 ] >>90 環境の情報が足りないかと。 授業単元からして、、グラフの作成ソフトが別にありそう。 あとX-Windowは立ち上がってる? それと、使うライブラリ、何か指定は? これはどうみても、Cというより物理の問題になってる気がw 91の補足。 gnuplotを使うなら、Cから標準出力に、gnuplotのコマンドを吐いて、 パイプでつなぐ。 = Cの宿題ではなさそう とりあえず時間がないので、早めに情報出したほうが良いと思われ。 もう一個。 Cで書く前に、グラフ作成ソフトである程度結果をつかんでから始めたほうが早いです。
95 名前:=92 mailto:sage [2008/11/03(月) 05:36:14 ] >>90 う" 問題よく見たら、ただのトラップかw この式、グラフを書く時はほとんど定数扱いで、 変数はφとxとzだけ・・・ 2次元の平面(x-z)で、21x41のマスをつくって、そこの値を計算。 って、表計算と同じw ただ、マス目の中のデータ(数値)を可視化する要素が足りない。 とりあえずExcelでも立ち上げて、各マス目のデータ計算してくるか。。 問題はExcelが手元にない事だが。
96 名前: ◆NiyDyBDWQM mailto:sage [2008/11/03(月) 05:46:19 ] [1] 授業単元:プログラミングC [2] 問題文(含コード&リンク): <関数 配列渡し> 以下のようなプログラムを作成しなさい. 2つの整数配列(要素数は任意)、配列Aと配列Bを受け取り,配列AとBの要素の値 の平均値(実数)をそれぞれ計算し、平均値が大きい方の配列の内容(整数)と平均 値(小数点第1位まで)を表示する関数を作る。また、この関数を使って以下の2つ の配列の平均値を比較するプログラム. 配列A{1,2,3,4,5} 配列B{2,3,4,5,6} ※関数に配列を渡す時は、関数内では配列の大きさがわからないので、以下の例 のように配列と配列サイズを渡す必要がある。 void func(int vector_a[], int vector_a_size); int vec[3] = {1,2,3}; func(vec, 3); // func(vec, sizeof(vec)/sizeof(int)); [3] 環境 [3.1] OS: WindowsXP [3.2] コンパイラ名 Cygwin [3.3] 言語:C [4] 期限: 11月3日 10時まで [5] その他の制限: まだまだ序の口のほうです。 期限まで時間があまり無いですが、どうか宜しくお願いします。
97 名前:=92 mailto:sage [2008/11/03(月) 06:23:45 ] >>96 期限なさすぎw というか、この時間に誰か起きてることを期待しちゃいけません。 ま、一瞬で終わる問題だが・・
98 名前:=92 mailto:sage [2008/11/03(月) 06:49:10 ] >>96 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7924.txt 釣りかと思ったけど、アップしとく。 ・doubleはどうせあふれないと想定されてるっぽいので、オーバーフローのチェック省略。 必要なら改造しましょう。まだ時間は十分あるw
99 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 07:01:46 ] >>98 ありがとうございました。 非常に助かりました。
100 名前: ◆7777.bQf6c mailto:sage [2008/11/03(月) 08:29:18 ] [1] 授業単元:プログラミング [2] 問題文(含コード&リンク): ttp://kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7925.txt [3] 環境 [3.1] OS: Windows XP [3.2] コンパイラ名とバージョン: Visual stdio 2005 [3.3] 言語: C [4] 期限: 11/3 24:00 [5] その他の制限:2次元配列とfor文を使ったものでお願いします
101 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 08:42:44 ] >>99 関数が題意満たしてないように見えるんだけどw
102 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 09:50:03 ] >>100 うpろだtxtの結果表示(AB)は正しいのでしょうか? どこを計算して先頭の"52"を導き出すのかがイマイチ・・・
103 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 09:58:47 ] >>102 52だと思うが。
104 名前:100 ◆7777.bQf6c mailto:sage [2008/11/03(月) 10:05:27 ] >>102 先頭の52の求め方は (5*9)+(-2*-1)+(1*5)=52 となります 行列の積の計算方法については、こちらを参照して下さい 【3行3列の行列の和と積の計算方法を教えて下さい。 -OKWave】 ttp://okwave.jp/qa87490.html
105 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 10:11:39 ] >>100 int AB[3][3]; for (i = 0; i < 3; i++) { for (j = 0; j < 3; j++) { AB[i][j] = A[i][0]*B[0][j] + A[i][1]*B[1][j] + A[i][2]*B[2][j]; } } printf("== AB ==\n"); for(i=0;i<3;i++){ for(j=0; j<3; j++){ printf("%3d",AB[i][j]); }printf("\n"); }
106 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 10:20:48 ] すまん、俺が寝ぼけているのかもしれんが、>>100 の結果、やっぱおかしくないか?
107 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 10:25:32 ] #include <stdio.h> #define N 3 int main(){ int i,j,ii; int a[N][N]={{5,-2,1},{9,2,9},{-3,7,4}}; int b[N][N]={{9,6,3},{-1,-2,-3},{5,3,1}}; int ab[N][N]; for(j=0;j<N;j++){ for(i=0;i<N;i++){ ab[j][i] = 0; for(ii=0;ii<N;ii++){ ab[j][i] = ab[j][i] + a[j][ii] * b[ii][i]; } } } printf("== AB ==\n"); for(i=0;i<N;i++){ for(j=0; j<N; j++){ printf("%3d",ab[i][j]); }printf("\n"); } return 0; }
108 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 10:27:42 ] 実行結果でのAの(2, 3)成分とコード中でのそれが食い違ってる。 たぶん、実行結果のAが正しい
109 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 10:31:08 ] わざとこういうミスをして、悩む学生を見ながらニヤニヤする変な教官とかいそう。
110 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 10:49:24 ] そういう言い訳をする教官もいそう。
111 名前:60=71=77 mailto:sage [2008/11/03(月) 11:25:53 ] 皆様、ありがとうございます・・・! >>85 さんのソースに、>>92 さんの削除関数をアレンジして加えたのですが、 リストの一番後ろの要素を削除してそれをPrintListすると無限ループしてしまいます。listのtail部分がおかしくなっているからだと思うのですが、どう直せばよいか教えていただけないでしょうか? kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7926.txt 削除関数のアレンジした部分はコメントの※印部分です。お願いします。。
112 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 11:28:45 ] [1] 授業単元:計算機システム [2] 問題文(含コード&リンク): 浮動小数点数のビットパターンを表示するプログラムを作成せよ。 そして、1.0 および、0.1, NAN, マイナス無限大, プラス無限大, その他適当な小数がどのようなビット列で表現されているか確認せよ。 [3] 環境 [3.1] OS:Linux [3.2] コンパイラ名とバージョン: [3.3] 言語: C [4] 期限: 11月5日 [5] その他の制限:なし おねがいします。
113 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 11:38:58 ] なんか漠然とした問題だな
114 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 12:40:22 ] >>112 #include <stdio.h> #include <limits.h> int is_little_endian(){ int x = 1; return *(char*)&x; } typedef unsigned char byte_t; void print_bytebits_(byte_t value){ byte_t mask = 1 << (sizeof(byte_t) * CHAR_BIT - 1); for(;mask; mask >>=1) putchar(mask & value ? '1' : '0'); } void print_bits(void *p, int bytesize){ byte_t *p_byte = (byte_t*)p; int i; if(is_little_endian()){ for(i=bytesize-1; i>=0; i--) print_bytebits_(p_byte[i]); }else{ for(i=0; i<bytesize; i++) print_bytebits_(p_byte[i]); } } int main(){ double values[] = {1.0, 0.1, 0.0/0.0, -1.0/0.0, 1.0/0.0, -3.14}; int i; for(i=0; i<sizeof(values)/sizeof(*values); i++){ print_bits(&values[i], sizeof(double)); printf("(%.02f)\n", values[i]); } return 0; }
115 名前:デフォルトの名無しさん [2008/11/03(月) 12:46:05 ] [1] 授業単元:C [2] 問題文(含コード&リンク): カレントディレクトリの".txt"という拡張子を持つすべてのファイルを 読み込み、ファイルに記載されているデータを二倍して".TXT"というファイルに出力しなさい。 ".txt"の拡張子前のファイル名はランダムな数字列であり(例:029340.txt)、 ファイルの中身は以下の5行1列からなる数値ファイルである。 .txt 3 5 2 4 5 .TXT 6 10 4 8 10 [3] 環境 [3.1] OS:windowsXP [3.2] コンパイラ名とバージョン:borland C++ [3.3] 言語: C [4] 期限: 11月4日 [5] その他の制限:なし
116 名前:115 [2008/11/03(月) 12:47:39 ] >>115 すいません間違えました。 .TXTではなくて.Tです。
117 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 12:52:06 ] 半角を全角にするのもやればいいのか?
118 名前:デフォルトの名無しさん [2008/11/03(月) 12:55:34 ] >>117 すいません。 数値は半角です。
119 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 13:13:29 ] >>113 さん 遅くなってごめんなさい。 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7927.txt 修正箇所は申し訳ないのですがDIFFツールなどで調べてください。
120 名前:119 mailto:sage [2008/11/03(月) 13:15:53 ] アンカーミス >>111 さんでした 釣ってきます
121 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 15:28:51 ] >>115 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7928.c ファイル名が 数字のみ.txt であるかのチェックはあり、 中身が数字のみか、5行1列かのチェックはないんで そうなっているファイルを用意しておくこと。
122 名前:help me [2008/11/03(月) 15:37:36 ] >>65 お礼遅れましたすみません。 とても助かりました! ありがとうございました。(^0^)
123 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 16:11:32 ] [1] 授業単元:C++ [2] 問題文(含コード&リンク):kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7929.txt [3] 環境 [3.1] OS: Windows [3.2] コンパイラ名とバージョン:VS2008 [3.3] 言語:C++ [4] 期限:[2008年11月08日まで] よろしくお願いします。
124 名前:デフォルトの名無しさん [2008/11/03(月) 16:20:08 ] [1] 授業単元: 画像処理プログラミング [2] 問題文(含コード&リンク): kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7930.txt [3] 環境 [3.1] OS: UNIX [3.2] コンパイラ名とバージョン: [3.3] 言語: C [4] 期限: 11月4日 よろしくお願いします。 期限が近いのにまったく手が出ません。
125 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 16:28:13 ] >>124 久々にめんどくさそうなの来たなwwww
126 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 16:30:47 ] 何をwwwwで笑っているのか知らんが、面倒臭いと思うのも個人の主観。 ぜんぜん面倒臭くない、単なるバイナリーデータの操作だろ、そんなの。 むしろ、オラッ、強敵が現れてなんだかwktkしてきた、ってゴクウみたいな 奴もいるかもしれんぞ?
127 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 16:35:43 ] >>126 もちろん>>124 を明日までに一から作れる暇とスキルがあっての書き込みだよな?
128 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 16:44:45 ] >>126 多分おれのこと言ってるんだと思うけど今回はお前に宿題ゆずってやるよ
129 名前:100 ◆7777.bQf6c mailto:sage [2008/11/03(月) 16:45:49 ] 返信遅れてすいません txtに書かれたプログラムは私の打ち間違いです、失礼しました それと>>105 さん>>107 さん、ありがとうございました
130 名前:60=71=77=111 mailto:sage [2008/11/03(月) 16:56:46 ] >>119 さん ありがとうございます。正常に動きました。 その他助けてくださった方々、本当にありがとうございました!
131 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 16:58:01 ] >>126 さんが明日までにコンバータ作ってくれるそうです。良かったですね>>124 とりあえず両手を空に挙げてやるから元気玉でも集めて作ってみろよ。面倒じゃないんだろ?>>126
132 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 17:05:49 ] >>1 読める?読めない?聖徳太子(ry 要するに、個人を指定、特定して答えてもらうスレじゃないんだよ、ここ? やってくれるよ、良かったね?お前がやれよw
133 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 17:13:25 ] >>124 はスルーする流れなのか?
134 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 17:26:35 ] >>66 レス遅れてすみません>< 1.出力は ・縦ではなく、横にならべる。つまり行。縦は1024列(絶対)。 ・各行は、data.txtのデータ(data[i])が(ave) + 5*(sd)以上の時だけ出力する しかし、[0][0],[0][1],[0][2],・・・,[205][3]をひとつの区切りとする。 この1024個中の標準偏差(ave) + 5*(sd)以上の値を出力する。 次に[206][0],[206],[1],・・・,[411][2],[411][3]の1024個中の標準偏差以上の 値を出力する。このとき、peak.txtに改行して出力する。 このようにdata.txtの値を1024個で区切る。 2.十分なメモリを確保のところ ソースは1次元に見えるけど、出力ファイルには2次元で!! mallocでメモリを確保したいのは、data.txtが約16Mもあるから!! 3.文章に間違えありました!!!! 5行209921列のデータではなく、209921行5列のデータです。 なので [0][0],[0][1],[0][2],・・・,[205][3] [206][0],[206][1],・・・,[211][3] [211][0],[211][1],・・・,[216][3] [217][0],[217][1],・・・,[222][3] ・ ・ ・ と1024個で区切れる。 どうでしょうか? プログラムよろしくお願いします。
135 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 17:27:45 ] >>132 必死なのは分かるが、とりあえず聖徳太子(ryのテンプレ教えてくれ。 あと>>124 は最近傍法での拡大くらいまでは、と思ってるが、さすがに(4)はなんとかいうフォーマットから調べないかんなあ。
136 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 17:40:44 ] フォーマットはぐぐれば一発だよ だからさっさと作っておくれー
137 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 17:57:05 ] >>124 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7931.txt こんな感じか? コンパイルすらしてないコードなんで動かなかったら適宜修正してくれ。
138 名前:137 mailto:sage [2008/11/03(月) 18:04:34 ] flee... orz
139 名前:デフォルトの名無しさん [2008/11/03(月) 18:16:38 ] >>135 > 必死なのは 誰とも分からない見えない人に答えさせようとしているお前。
140 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 18:42:00 ] 日本語かc/c++でおk。
141 名前:デフォルトの名無しさん [2008/11/03(月) 18:50:01 ] C言語で数字を小数第一位まで表示させるにはどうすればようでしょうか。
142 名前:デフォルトの名無しさん mailto:sage [2008/11/03(月) 18:51:23 ] %.1f
143 名前:=92 mailto:sage [2008/11/03(月) 19:43:57 ] 久しぶりに夕方まで寝てしまった。。。 >>101 問題読み違ってた? ま、あとはがんばれw
144 名前:=92 mailto:sage [2008/11/03(月) 20:02:13 ] >>90 kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/7934.txt 計算する所までは実装。計算結果は@:dataout1.csv、A:dataout1.csvに出力。 グラフ化の部分は、環境がわからんのでパス。3次元のグラフを*で書く気にならなかった。 csv内のデータは、横方向:x(-20〜20)、縦方向:z(-40〜40)、値:φ(x,z) 電荷ごとに、0除算のオーバーフローをdoubleの最大値として処理しているので、 Aの結果が上下対象になっていません(斜めにdoubleの最大値が入る)。 計算結果の検算とAの式のチェックは、がんばれ。 Aの処理はコメントアウトしてあります。 Aを使う時は@の処理をコメントアウトしてから、 Aの処理のコメントアウトを解除します。 Aは、せめて式とdの値を書かないと。 ここは電磁気学の板じゃないので。 適当に調べてかいといたけど・・
145 名前:=92 mailto:sage [2008/11/03(月) 20:11:49 ] >>134 っ計算機 5も209921も奇数。よって、5x209921も奇数。 1024は偶数。 従って割り切れることはありません。 +[0]〜[3]なら、要素数は4。 問題を解く前に、概算するくせをつけましょう。