07/11/23 23:50:40
>>682
URLリンク(ja.wikipedia.org)
684:デフォルトの名無しさん
07/11/23 23:51:45
>>682
doubleの有効桁数を超えてるとか。
685:デフォルトの名無しさん
07/11/23 23:57:53
多売長ライブラリ
686:デフォルトの名無しさん
07/11/24 00:15:23
>683
倍精度浮動小数点で普通使われるIEEE 754 形式だと仮数部52ビットだけど、
pow(5,23)で52bitを超えるから、以降は誤差が出る。
誤差を避けるためには自分で作るしかない。
でも多分そういうアルゴリズムは探せばあるよ。
687:デフォルトの名無しさん
07/11/24 01:53:27
0*0.003=0
をlog計算するためにプログラムでかくにはどうすればいいですかね?
0*確率なら0になるから処理の結果に影響ないんだけど
logだと0にならないんで困るわ。
688:デフォルトの名無しさん
07/11/24 01:54:20
?
689:デフォルトの名無しさん
07/11/24 02:09:44
わからないかな?
たとえばこの図であらわすと
URLリンク(kossie.net)
startから1回目の移動で↑と↓に移動できるそのときの確率が0.5と0.5
start地点の状態確率が1とすると↑と↓に移動した段階の状態確率はそれぞれ0.5 0.5
プログラム的に1回の移動ごとに、すべての状態をまわって、
そのあとに2回目の移動をすることにしてます。そうじゃないと作れないので。
これを小数点でなら最初すべての状態の確率を 0にしておけば、それぞれの移動ごとに
すべての状態をまわっても0*移動確率 =0になるので変な数値が値がでることはありません。
ただlogで計算する場合に、logはlog(A*B)=logA+logBという性質があるので
Aが0であってもBが0でなければ数値は残ってしまういうわけ。
これでプログラムになやんでるんですよ。
690:デフォルトの名無しさん
07/11/24 02:13:56
そもそもlogxって定義域x>0だろが
691:689
07/11/24 02:35:46
まあ問題はこういう感じなんですけど、図は>>689のとおりです
いま、start,1,2,3,10,11,endという状態がありまして、
以下のような確率で移動することとします。
最初はstartで最後はendです。startの状態確率は1.0です。
1.0から移動する確率をかけると状態1のその時点での状態確率が0.5、状態2の状態確率が
0.5となります。
ただし状態1は入ってくる矢印が3つですので、その時点では0.5ですが
次の状態に状態1から状態1へ移動すると0.5X0.6の計算をして0.3となるわけで
す。この(startから状態1への移動確率)
(状態1の状態確率)X(状態1から状態1への移動確率)と、(状態11の状態確率)X(状態11
から状態1への移動確率)の和が状態1の状態確率となります。
startから状態10に移動したり、状態2に移動したりして計算をしていって
endにきたときの最終状態確率を求めよ。っていうのが問題です。
これをlogで計算しないといけないっていう前提にプログラムを作るとしたら
どうつくっていきますか?ただし状態に入ってくる3つの値は比較しながら
計算しないといけないんでね。logの計算なので。
692:デフォルトの名無しさん
07/11/24 02:39:14
>>689
なんだお前か
氏ね
693:689
07/11/24 02:46:15
どうせできないのにいばんな。
694:デフォルトの名無しさん
07/11/24 02:47:25
非友好的な態度だな
695:デフォルトの名無しさん
07/11/24 03:40:22
負の無限大?
696:デフォルトの名無しさん
07/11/24 03:57:50
>>691
人に説明する気はありますか?
宿題スレでも、簡単なことを訳の分からない説明してたし
考えていることを整理してみてはどうでしょう?
エスパーしておくと、対数を使うのは外部データの入出力のときだけで
内部での計算は対数を使わなくていいんじゃないかと・・・
(どうせ浮動小数点だし)
697:デフォルトの名無しさん
07/11/24 09:14:10
「 ̄ `ヽ、 ______
L -‐ '´  ̄ `ヽ- 、 〉
/ ヽ\ /
// / / ヽヽ ヽ〈
ヽ、レ! { ム-t ハ li 、 i i }ト、
ハN | lヽ八l ヽjハVヽ、i j/ l !
/ハ. l ヽk== , r= 、ノルl lL」
ヽN、ハ l ┌‐┐ ゙l ノl l
ヽトjヽ、 ヽ_ノ ノ//レ′
r777777777tノ` ー r ´フ/′
j´ニゝ l|ヽ _/`\
〈 ‐ 知ってるが lト、 / 〃ゝ、
〈、ネ.. .lF V=="/ イl.
ト |お前の態度が とニヽ二/ l
ヽ.|l 〈ー- ! `ヽ. l
|l気に入らない lトニ、_ノ ヾ、!
|l__________l| \ ソ
698:デフォルトの名無しさん
07/11/24 09:21:52
>>689
>ただlogで計算する場合に、logはlog(A*B)=logA+logBという性質があるので
>Aが0であってもBが0でなければ数値は残ってしまういうわけ。
なんで、そんな偉そうにウソを語るんだ。
699:デフォルトの名無しさん
07/11/24 09:53:50
log0 は未定義だから log(A*B)=logA+logB で A が 0 の場合を考える事自体がナンセンス
700:デフォルトの名無しさん
07/11/24 10:03:19
>>689
よく分からんが、log0って出来ないんじゃないの?
701:デフォルトの名無しさん
07/11/24 10:06:58
エスパーすると、確率を log した値で保持しておいて、
確率変化を積じゃなく和で表現したいんだろうな。
log(0) は CPU によっては -inf (マイナス無限大) として扱われるから、
そういう CPU では特に問題は発生しないと思うんだけど。
702:デフォルトの名無しさん
07/11/24 10:45:05
>>683-686
レスサンクス!
結局、多倍長演算をするためにGMPとやらを入れてみました。
しかしGMPの関数を解説してるサイトの少ないこと…
どんな関数があるのか、引数の意味は何かとかさっぱり分からないorz
703:デフォルトの名無しさん
07/11/24 11:32:52
練習で、サーバーソケットとクライアントソケットを両方持つプログラムを作ってます。
サーバーはサーバーでリッスンさせといて、クライアントはメッセージを入力すると相手サーバーへ飛ぶ、
と考えたんだけど、先にサーバーソケットをaccept()でループさせとくと、後のクライアント処理に行けなくて困ってる。
スレッド使わないとムリ?
704:デフォルトの名無しさん
07/11/24 11:55:20
>>703
>スレッド使わないとムリ?
無理。素直にスレッド立てれ。
705:デフォルトの名無しさん
07/11/24 11:57:22
プロセスでもいいけどな
706:デフォルトの名無しさん
07/11/24 12:00:22
selectとその仲間
全然(標準)Cじゃねーじゃねーか
707:デフォルトの名無しさん
07/11/25 00:04:32
for文とwhile文の使い分けがよく分かりません。
苦Cのサイトに、「for文はwhile文を拡張した文」と書いてあったのですが、
while文が先にできて後でfor文を追加したのでしょうか?
while文でなければできないことや、while文でやった方がいいこと、またその逆など、
ありましたら教えてください。よろしくお願いいたします。
708:デフォルトの名無しさん
07/11/25 00:10:58
>>707
とりあえずループカウンタをつかってるループはfor()を使っておけばいいんじゃないの?
709:デフォルトの名無しさん
07/11/25 00:17:10
>>707
while文でできてfor文でできないことや、その逆のことは、ない。
i = 0;
while (i < 10) {
....
i++;
}
と
for (i = 0; i < 10; i++) {
...
}
のどちらが読みやすいか?
その程度の問題。
710:デフォルトの名無しさん
07/11/25 00:19:45
do{}while(); // 必ず一回は行う処理
for(;;) // ループ途中で continue を行っても for の第三項が実行される
711:デフォルトの名無しさん
07/11/25 00:36:29
>>708-710
ありがとうございます。
文法的にwhile文の方が見やすいので、個人的にはそちらを使おうかと思っています。
一般的にはどういう使い分けがされてるとか、「慣習」や「常識」みたいのはありますでしょうか?
712:デフォルトの名無しさん
07/11/25 00:54:11
文字列処理とか数値処理とかで使い分けるだろ。
713:デフォルトの名無しさん
07/11/25 01:03:14
ここでfor文の方が速いからfor文使え、とその後200レス程費やす無駄な議論を起こす為のネタ投下
714:デフォルトの名無しさん
07/11/25 01:04:49
慣習とかは無いだろうけど,
回数が固定なら for,未定なら while が一般的だと思う
たとえば,「荷物を10個選ぶ」なら for で,「荷物を10kg分選ぶ」なら while とか
715:デフォルトの名無しさん
07/11/25 01:07:00
そうだな
内容の容量の制限したいときにforではせんわな。
あープログラムつくらないといけないのに
作る気がしない。
作り始めたら5,6時間いけるのに
そういうのが全然ない。
716:デフォルトの名無しさん
07/11/25 09:10:10
たしかに for でも while でもよいネ。
オイラは無限ループは while 使うようにしてるな。
do while は使わなくなった。
717:デフォルトの名無しさん
07/11/25 09:50:56
ループするごとに毎回行いたい処理があれば for を使うね。
continue しても実行されるから。
718:デフォルトの名無しさん
07/11/25 11:06:17
vcだとwhile(1)は警告レベル最大だと文句言われるのでfor(;;)を使うようになった
この辺の習慣は環境で変わるんだろうね
719:デフォルトの名無しさん
07/11/25 11:08:38
泣く泣く for (; ;) を使うように
720:デフォルトの名無しさん
07/11/25 13:30:51
>>718
どういう警告?
721:デフォルトの名無しさん
07/11/25 13:42:40
>>720
C4127
722:デフォルトの名無しさん
07/11/25 15:10:01
CとC++はもう仲良くできないの?
C99すごすぎ。
723:デフォルトの名無しさん
07/11/25 17:28:24
認識率1%とかの実験のプログラムを前の先輩をつくられて
再実験でそのプログラムを作ってるんだけど。
データ100でそのうちの何個かで認識率を出すって感じで
今ようやくデータ1つで数値を出せるようになった。
データ100個をプログラムで入力できるようにして自動でしたいんだけど
結構複雑。
データ1つ入力して値をだして100回するのも
認識率1%とかいうやって意味あるのか的な感じがして自重してる。
しかしプログラムの内容を率でだされるのっていやだね。
724:デフォルトの名無しさん
07/11/25 17:36:31
日記帳にでも書いてろカス
725:デフォルトの名無しさん
07/11/25 18:57:23
URLリンク(www.nicovideo.jp)
これか
726:デフォルトの名無しさん
07/11/25 19:48:10
文字列処理を極めたいのですが、何から手を付けたらいいですか?
727:デフォルトの名無しさん
07/11/25 20:01:28
左から。
728:デフォルトの名無しさん
07/11/25 20:02:51
まずは文字列の表現方法を考えることから
729:デフォルトの名無しさん
07/11/25 20:03:10
修辞的疑問文というやつだな
730:デフォルトの名無しさん
07/11/25 20:13:07
ファイルを読み取る時に一文字ずつ読み取る方法と
一行ずつ読み取る方法がありますが、
どういう場合に使い分けるんですか?
731:デフォルトの名無しさん
07/11/25 20:14:23
カンタンなことだ。
ファイルを1文字ずつ読み取りたい場合は1文字ずつ読み取る方法を使い、
1行ずつ読み取りたい場合は1行ずつ読み取る方法を使う。
732:デフォルトの名無しさん
07/11/25 20:16:09
その日の気分による
733:デフォルトの名無しさん
07/11/25 20:30:51
一行ずつ、もしくは一文字ずつ読み取らなければいけない場合とは、
例えばどんな場合がありますか?
734:デフォルトの名無しさん
07/11/25 20:43:56
>>733
行に意味があるときには行単位で読んだほうが楽
行に意味がないときには文字単位で読んだほうが楽
735:デフォルトの名無しさん
07/11/25 22:13:40
バイナリファイルは1文字ずつ読んで、
テキストファイルは1行ずつ読む。
736:デフォルトの名無しさん
07/11/25 22:39:40
>>735
さらっと嘘教えるな
737:デフォルトの名無しさん
07/11/25 23:10:37
型変換しないのに型変換するとコストかかりますか?
たとえばunsigned int型を同じ型でキャストした場合です
738:737
07/11/25 23:17:16
どうやらたいして差がないことが分かりました
739:デフォルトの名無しさん
07/11/25 23:39:11
まず間違いなく出力は1バイトもたがわないと思う。
740:デフォルトの名無しさん
07/11/26 00:22:38
ビルドしてfc /bで比べればいいんじゃね
741:デフォルトの名無しさん
07/11/26 01:08:03
>>714
分かり易い説明をありがとうございます。
>>709の例で言うと、for文を使う方が一般的、ということですね。
どちらも i を宣言しないといけないことに変わりはないんですね。
742:デフォルトの名無しさん
07/11/26 05:05:13
ループの終了条件がループカウンター以外の場合はwhileを使う。
ループごとにある関数を呼んで、その結果が真の時のみループを抜ける、とかな。
while (func() != 0)
{
~何かの処理~
}
まあforでも実現できるから、どっちでもいいんじゃない?
743:デフォルトの名無しさん
07/11/26 09:16:58
C言語の参考書Lvを卒業して、線形リストとかアルゴリズムみたいなのをある程度組んでみた。
30日位考えれば作れるようなプログラムとかどのような物があります?
大学にも行けなかったような頭なので、そこまで難しい物はまず出来ませんが。
744:デフォルトの名無しさん
07/11/26 09:31:01
>>743
トランプのポーカーを AI 付で
745:デフォルトの名無しさん
07/11/26 09:36:18
>>743
OS。本が売ってるからそれに従えばおk
746:デフォルトの名無しさん
07/11/26 09:55:58
>>744
色々ネットにソースありましたが、AIって部分が難しそうですね・・・
ゲーム作ってみたかったので参考にさせて頂きます。
>>745
アセンブラも使うそうですし、OSとなると自分には無理な気がしてならないですがw
30日でOSが出来るならとなると少し興味もありますね。
レビューのみでは分からなかったのでこれから本屋行って二つを見て周って来ます
レス下さった方有難うございました
747:デフォルトの名無しさん
07/11/26 13:45:16
int a[256]={0} という配列を定義して
例えば1024をscanfでこの配列に
a[0]=1024 , a[1]=0 ,a[2]=0,......,a[255]=0
ではなく
a[0]=4 ,a[1]=2, a[2]=0, a[3]=1.a[4]=0,.....,a[255]=0
という風に格納したいのですが、どういう風にプログラムを書けばいいのか思いつきません
よろしくお願いします。
748:デフォルトの名無しさん
07/11/26 13:48:11
int n, a[256] = {0}, i;
scanf("%d", &n);
for(i=0; n; i++, n/=10) a[i] = n % 10;
749:デフォルトの名無しさん
07/11/26 14:06:25
>>748
ありがとうございます!
int型やdouble型以上の桁の数字を扱う方法として
一桁ずつ格納する方法ならば!と思ったのですが、
どちらにしろ一度int型の変数に代入しないといけないことにプログラム見て気付きましたorz
char型の配列(例えばstr[256])に文字として数値を文字として格納した後に、
それをint型の配列(a[256])に入れなおすことって出来ませんよね…
750:デフォルトの名無しさん
07/11/26 14:19:16
>>749
こういうこと?
char buf[] = "123456789";
int val[sizeof(buf)];
for (unsigned ic = 0; ic < sizeof(buf); ++ic) {
val[ic] = buf[ic] == '\0' ? 0 : buf[ic] - '0';
}
751:デフォルトの名無しさん
07/11/26 14:20:01
int i, j=0, a[256];
char str[256];
scanf("%s", str);
for(i=0; str[i]; i++);
whil(i--) a[j++] = str[i] - '0';
752:デフォルトの名無しさん
07/11/26 14:20:10
void array_double(int *a, int n)
{
int i;
for(i=0;i<n-1;i++,n--)
{
a[i] = a[n-1];
}}
配列aとそのサイズnを受け取り、要素を逆順にするプログラムを考えているんですが、
うまくコンパイルすることができず、1,2,3,4,5と入力すると、5,4,3,4,5と出力されます。
どこがおかしいのでしょうか?
753:デフォルトの名無しさん
07/11/26 14:25:38
>>752
>どこがおかしいのでしょうか?
頭。
コードと結果が合致してさえいないぞ。自分のコードくらい間違うな。
754:デフォルトの名無しさん
07/11/26 14:29:45
>>752
ヒント: 上書きと交換は違う
755:デフォルトの名無しさん
07/11/26 14:31:48
>>753
ヒント: ピントが外れている
756:デフォルトの名無しさん
07/11/26 14:32:11
>>753
お前の頭もおかしいよ
757:デフォルトの名無しさん
07/11/26 14:36:06
>>752
自分の頭(紙と鉛筆でもいい)の中で実行して
1行ずつ変数の中身がどうなるか考えてみよう
ループを展開するんだ。
a[0] = a[5-1];
a[1] = a[5-1];
・
・
・
758:デフォルトの名無しさん
07/11/26 14:36:57
>>757
お前もちゃんとコード見ろ
759:753
07/11/26 14:40:36
とりあえず、>755のお蔭でn--を見落としていたのは判ったw
>>757
同士よw
760:デフォルトの名無しさん
07/11/26 14:52:32
>>752
a[i] = a[n-1] を
int temp = a[i];
a[i] = a[n-1];
a[n-1] = temp;
にすればok
761:デフォルトの名無しさん
07/11/26 14:58:31
Cに交換演算子が欲しいと思う恭子の頃。
762:デフォルトの名無しさん
07/11/26 15:31:04
>>761
具体的にどう実装する?
763:デフォルトの名無しさん
07/11/26 15:33:38
>>762
>760の例なら
a[i] <> a[n - 1];
とか。
評価の回数を減らせるし、swapマクロを作って自爆することもなくなるし、
CPUに交換ニモニックがあれば使えるべさ。
764:デフォルトの名無しさん
07/11/26 16:08:54
今大学でプログラミング授業を取ってるんだが、色々とワカンネorz
演習内容うpするので教えてくれませんか?
765:デフォルトの名無しさん
07/11/26 16:16:21
>>764
スレ違い
766:デフォルトの名無しさん
07/11/26 16:18:44
>>765
キティーだから許して。スレ違いだったらスマン
板いろいろ探したんだが、何処で聞いたらいい?
ググレ以外の回答を頼むw
767:デフォルトの名無しさん
07/11/26 16:26:09
C/C++の宿題を片付けます 100
スレリンク(tech板)l50
768:デフォルトの名無しさん
07/11/26 16:26:32
>>764
宿題スレも見つけられないなら大人しく首括っとけ。
769:デフォルトの名無しさん
07/11/26 17:57:03
Visual C++ 2005を使用しています。
文字列をLONGLONG型の整数値に変換したいんですが、atoll関数が見つかりません。
Visual C++ 2005の環境では、atoll関数は自作するしかないでしょうか。
770:デフォルトの名無しさん
07/11/26 17:58:25
>>769
つ[strtoll()]
771:デフォルトの名無しさん
07/11/26 18:42:36
_atoi64
772:デフォルトの名無しさん
07/11/26 18:51:11
boost::lexical_cast
773:769
07/11/26 18:53:19
>>770-772
ありがとうございます。
_atoi64でいけました。
774:デフォルトの名無しさん
07/11/26 19:59:33
>>770
VC2005はC99に未対応じゃね?
775:デフォルトの名無しさん
07/11/26 20:56:49
変な質問ですが、C言語をマスターするのにだいたいどのくらいかかりますか?
776:デフォルトの名無しさん
07/11/26 21:01:58
オレにも教えて下さい。C言語って何が出来ますか?
入門書卒業後何をしたらいいのやら。
グラフィック系統の本みたけど、これを利用してぱらぱら漫画みたいなの作れないですか
777:デフォルトの名無しさん
07/11/26 21:05:11
Cでできないことはほとんどない
778:デフォルトの名無しさん
07/11/26 21:06:05
>>776
それだけなら画像表示ツール自身でできるからなぁ。
あんたの質問は、「英語で何ができますか?」と同じくらい無意味なんだよ。
779:デフォルトの名無しさん
07/11/26 21:40:46
#include <stdio.h>
int main(void)
{
FILE *fp;
int x;
int y = 30;
fp = fopen("test.txt","r");
fscanf(fp,"%d",&x);
printf("%d",x);
fclose(fp);
fp = fopen("test.txt","w");
fprintf(fp,"%d",x);
fscanf(fp,"%d",&x);
printf("%d",x);
fclose(fp);
return(0);
}
------test.txt-----
10
-----------------
馬鹿な質問で申し訳ないです。
実行結果が107になるんですが、何か見落としてるのでしょうか。
780:デフォルトの名無しさん
07/11/26 21:47:04
"w" なのになんで fscanf を?
781:デフォルトの名無しさん
07/11/26 21:48:45
>>779
>何か見落としてるのでしょうか。
夢
冗談さておき、"w"でオープンしたストリームからは読み込めません。
まして、fprintf()で出力した先には何もありません。
782:デフォルトの名無しさん
07/11/26 21:49:26
あ、ホントだ。
ありがとうございます。
また"r"で開きなおさないとダメなんですね。
"r+"とか"w+"の使い方もいまいち不明だし。
783:デフォルトの名無しさん
07/11/26 21:58:29
ついでに質問です。
"r+"と"a+"の違いって何でしょう?
両方ともファイルに出力したら追記されますよね。
単純にファイルが新規に作成されるか否かですか?
784:デフォルトの名無しさん
07/11/26 22:01:41
r+ は途中にも書き込める。
a+ はファイルの終わりにしか書き込めない。
785:デフォルトの名無しさん
07/11/26 22:14:53
>>784
挿入可能って事ですか?
それとも上書きが出来るって事でしょうか。
色々試してみてるけど思うように扱えないです。
786:デフォルトの名無しさん
07/11/26 22:23:12
r+ は上書き可能。こんな感じ。 ポップアップ用アンカー >>786
#include <stdio.h>
#include <stdlib.h>
int main() {
static const char FILENAME[] = "test.txt";
FILE *fp;
int x = 0;
/* とりあえず 10 と書き込む */
fp = fopen(FILENAME, "w");
fprintf(fp, "%d", 10);
fclose(fp);
fp = fopen(FILENAME, "r+"); /* r+ で開く */
/* ファイルの先頭から数値を読み出す */
fscanf(fp, "%d", &x);
printf("%d\n", x); /* 10 と出力されるはず */
/* ファイルの先頭に移動して 30 と書き込む */
fseek(fp, 0, SEEK_SET);
fprintf(fp, "%d", 30);
/* またファイルの先頭に移動して数値を読み出す */
fseek(fp, 0, SEEK_SET);
fscanf(fp, "%d", &x);
printf("%d\n", x); /* 30 と出力されるはず */
fclose(fp);
return EXIT_SUCCESS;
}
787:デフォルトの名無しさん
07/11/26 22:32:56
分かり易い解説ありがとうございます。
上記の例で、"a+"だと、
10
1030
と出力されちゃうんですね。
fseek関数はまだ触った事ないので勉強してみようと思います。
788:デフォルトの名無しさん
07/11/26 23:07:17
/* fseekってイマイチよく分からん。 オフセットとかなんだか知らんが
読んだときか書き込んだときでかは忘れたけど、数字で
int型の4バイトの時と、char型の1バイトの時があってイミフ。
チラシの裏で馬鹿なレスだからスルーしてね^^ */
789:デフォルトの名無しさん
07/11/26 23:43:55
>>788
それは恐らくfseek()が判らないのではなくて、fprintf()で書き込むのかfwrite()で書き込むのかの
違いがよく判っていないんジャマイカ。
>>787
書き込み後は、fseek()(或いはそのサブセットのrewind())をするか、明示的にfflush()しないと
書き込んだ結果が実際のストリームに出力される保障がないことに注意。
まぁ、ファイル先頭に移動するにはrewind()の方が判りやすいだろうね。
790:デフォルトの名無しさん
07/11/26 23:56:48
条件によって01を記録し、
記録した情報を順番に読み取って01を判別し、
条件分けをしたいのですが思ったとおりになりません。。
具体的には、書き込み
FILE *fp;
char output = 0;
int bit = 0;
fp = fopen("bitstream","rb");
for(i=0; i...... )
{
if(bit == 8)
{bit = 0; fputc(output,fp);}
if(条件)
{手順1; output = ((output<<1) | 0x01); bit++;}
else
{手順2; output <<= 1; bit++;}
}
output = (output<<(7-bit));
fputc(output,fp);
読み込み
char a;
for(i=0; ){
if(bit == 8)
{a = getc(fp); bit = 0;}
if( ( a >> (7-bit) ) & 0x01 )
{手順1; }
else
{手順2; }
bit++;}
こんな感じで書いてるんですが、どこかおかしいところがあればご指摘ください。
791:デフォルトの名無しさん
07/11/27 00:13:53
float *a;
a = new float();
*a = 120;
float *temp = a;
これはOKですよね
float *temp = 120
これはなんでダメなんですか?
792:デフォルトの名無しさん
07/11/27 00:29:03
tempが格納するのはアドレスだから。
120を変数に格納して、その変数のアドレスをtempに渡すなどする必要がある。
793:デフォルトの名無しさん
07/11/27 00:30:17
newはC++なんだけど
794:デフォルトの名無しさん
07/11/27 00:30:49
セミコロンが無いから。
795:デフォルトの名無しさん
07/11/27 00:32:19
つまり
float *tempは、ポインタとして宣言してる状態で、そこにaのアドレスが入って、
temp = a となっている、ということですか?上の例だと
で、3行目の
*a =120 は aのアドレスをもったところに120をぶち込んでる、ということで
float *tempとは別ものなんですよね?
796:デフォルトの名無しさん
07/11/27 00:47:27
564.1
451.6
154.1
[EOF]
こういう風になってるテキストファイルがあるときに
「EOFまで数字をテキストファイルから読み込む」という作業をする場合はどうすればいいんでしょうか?
i=0;
while(1){
if(fread(&c,sizeof(char),1,fp)==EOF) break;
else
{
data[i]=fscanf(fp,"%lf\n",&value);
i++;
}
}
こんな感じにかいたらdata[0][1][2]には564.1 451.6 154.1 が入っているんでしょうか?
よくfreadとfscanfなどがわかっていないのでよろしくお願いします。
797:デフォルトの名無しさん
07/11/27 00:47:38
別もの。
*a=120の*はデリファレンス、float *tempの*はポインタ宣言。
798:ワカメ高専
07/11/27 01:05:59
[-3,3] fx=1/(1+5x^2) 分点の数 10個(n=9)
これをラグランジュで求めて結果を出力するプログラムを作れって(c or c++)言われたけどさっぱりでしゅ
799:デフォルトの名無しさん
07/11/27 01:44:24
>>798
課題丸投げは宿題スレへ
スレリンク(tech板)
800:デフォルトの名無しさん
07/11/27 01:49:31
>>796
i=0;
while(1){
if (fscanf(fp, "%lf", &data[i]) == EOF) {
break;
}
i++;
}
801:デフォルトの名無しさん
07/11/27 01:55:32
>>795
そう。上の例は
float *a;
a = new float();
*a = 120;
float *temp;
temp = a;
に等しい。下の例は
float *temp;
temp = 120;
ということになる。floatポインタに整数120は代入できない(型が異なる)のでエラー。
802:デフォルトの名無しさん
07/11/27 02:14:26
エラーにはならないだろボケ
803:デフォルトの名無しさん
07/11/27 02:16:13
>>791
別に駄目じゃねーよ。
期待してるのとは違う動作だろうけどな。
804:801
07/11/27 02:19:44
本当だ、エラーにはならんね、すまそ