C統合・質問スレッドat TECH
C統合・質問スレッド - 暇つぶし2ch263:デフォルトの名無しさん
05/02/03 16:45:28
>>261
%.7g
7の部分は精度。

264:デフォルトの名無しさん
05/02/03 16:46:59
10桁までなら%.10g

265:デフォルトの名無しさん
05/02/03 16:49:45
>>263
>>264
デキターありがとう!

>>262
よくわかりません。

266:デフォルトの名無しさん
05/02/03 16:50:59
>>259
>>260

しんでしまえ

267:デフォルトの名無しさん
05/02/03 16:55:03
>>266
>>259=>>260=>>263=>>264なんだがね。

268:259
05/02/03 19:08:08
違うよ。

269:259=268
05/02/03 19:09:08
つーか、260,263,264は私じゃない。

270:デフォルトの名無しさん
05/02/03 20:03:35
スレリンク(tech板:247番)n-

此処で訊いたら、こう言われましたが、何故かC言語の教本のサンプルはは
#include <stdio.h>

main() {
printf("Hello!");
return 0;
}

の様に空白欄が在るのに、自分が書いたのに空白欄を作ると
何故か上記のアドレスに出た、エラーが出てしまいます
調べても、本にも書いていませんでした、ご教授お願い致します。

271:デフォルトの名無しさん
05/02/03 20:09:55
あれ・・・?空白欄がない。
メモ帳で見るとあるんです。

272:デフォルトの名無しさん
05/02/03 20:28:27
ネタかなあ・・

ヒント:全角スペース

273:デフォルトの名無しさん
05/02/03 20:29:44
>>270
もしかすると、君は全角スペースを入れているのでないだろうか。
使っても良いのは半角スペースとアルファベット、半角の記号のみ。

274:デフォルトの名無しさん
05/02/03 20:32:56
ま、全角スペースを解釈しないコンパイラが悪いんだな。
うんうん。

275:デフォルトの名無しさん
05/02/03 20:33:39
それは言えてる。

276:デフォルトの名無しさん
05/02/03 20:34:03
ありがとうございました
要は空欄を空けてもいいけど、半角を使えと言う事でしょうか?

277:デフォルトの名無しさん
05/02/03 20:35:38
だめだこいつ
全然わかってない・・

278:デフォルトの名無しさん
05/02/03 20:40:51
すみません・・・
簡単に言えば、空欄(スペース)は空けない方がいいですよね?

279:デフォルトの名無しさん
05/02/03 20:43:28
ブラウン運動を非整数階微積分するプログラムを作成したのですが、上手く動きません。どこがわるいのでしょうか??
実行結果は数値を出し、エクセルでグラフ化しています。(window.hが使えないため)
#include <stdio.h>  #include <stdlib.h>
#include <time.h>  #include <math.h>
#define KMAX 100  #define XMAX 300
#define PI 3.14159265358979323846
double gar()
{double r = 0.0;
int i;
for(i = 0; i < 10; i++){r += ((double)rand() / RAND_MAX) - 0.5;}
return r;}
int main(void)
{int x, k;     float d; scanf("%f",&d);
double ek = PI * 2.0 * 0.7 / XMAX; double a = 5.0 – 2*d;
double f[XMAX];  double g[KMAX];
srand((unsigned)time(NULL));
for(k = 1; k < KMAX; k++){
g[k]=pow(( ek * rk ),-a/2);}
for(x = 0; x < XMAX; x++){  f[x] = 0.0;
for(k = 1; k < KMAX; k++){  double kx = ek * rk * x;
f[x] = f[x]+g[k]*(gar() * cos(kx) - gai() * sin(kx));}
printf("%g\n",f[x]);}
}

280:デフォルトの名無しさん
05/02/03 20:51:47
>>278
先頭に付けてもいいのは半角スペースとTABのみ。
スペースを空けるのは括弧同士の対応や意味的な違いを付けるためで、それをインデント
を付けるといいます。
これをしないとプログラムが見憎くなります。
的確にスペースを空けてください。

281:デフォルトの名無しさん
05/02/03 20:54:30
>>280
ありがとうございます!!
とりあえず、半角でスペースを空けたら、何の問題もなく
実行できました。
たぶん、全角だったのでエラー出たみたいでした。

282:ななし
05/02/03 22:14:53
どなたかC言語でHTTPリクエストを送信できるようなライブラリを
ご存知のかたいらっしゃいませんか?
ヘッダーを意識しなくてすむような形のもので!


283:デフォルトの名無しさん
05/02/04 00:40:29
WinInet

284:デフォルトの名無しさん
05/02/06 23:45:27
質問です。
以下の環境で、外部バイナリ(画像)ファイルを実行ファイルにリンクしたいのです。
何かスマートな方法はあるのでしょうか?

開発環境OS : FreeBSD 5.3
コンパイラ : gcc 2.95.4

調べたこと :
binutils の objcopy でオブジェクトファイルに変換n出来るかなと
ドキュメントを流し読みしましたが、出来そうにありません。

以上、よろしくお願いします。

285:デフォルトの名無しさん
05/02/09 12:50:59
Labeling.c1: "#include" expect "FILENAME"or<FILENAME>

このエラーを回避する方法わかる方いますか?よろしくお願いします

286:285
05/02/09 13:00:42
すみません。なんか初歩的入力ミス見たいです

287:デフォルトの名無しさん
05/02/09 13:14:18
ウインドウズプログラミングで仮想キーコードを使って
数字を表示したいのですが、0が表示できません。
keybd_event(VK_NUMPAD0,0,0,0);
keybd_event(VK_NUMPAD0, 0, KEYEVENTF_KEYUP, 0);
文法的に誤りがあるのでしょうか?
わかる方いましたら、お願いします。

288:デフォルトの名無しさん
05/02/09 13:36:43
誰かFTPサーバのソースプログラム教えてくれない?
今すぐ欲しいから誰かお願いします。Cの初心者なんで、そ
んなの簡単だよって思うかもしれませんが、どうかC言語
できる人よろしくお願いします。


289:デフォルトの名無しさん
05/02/09 13:41:16
Linuxのソースがあるべ、バカだな

290:デフォルトの名無しさん
05/02/09 13:51:38
おい!そいつは初心者だぞ。Linuxのソースの見れる方法も
ついでに教えてやれ。たぶんわかっとらんと思うぞ。

291:デフォルトの名無しさん
05/02/09 13:55:53
おっしゃるとおりです・・・。教えていただけます?


292:デフォルトの名無しさん
05/02/09 13:56:22
嫌だね、プ

293:デフォルトの名無しさん
05/02/09 14:03:09
RFC FTPでぐぐれば仕様書が出てくるからそれで作るのもいいかも

294:デフォルトの名無しさん
05/02/09 14:12:10
>>287
VK_NUMPAD0の代わりに'0'にしてみたらどう?

295:デフォルトの名無しさん
05/02/09 14:22:03
あのー・・・いまいちよくわかりません・・・。どなたかサンプルプログラム
書けるひといます?もしよかったらここに表示していただけたらと思い
ます。それをそのまま打ち込んでいくんで・・・。

296:デフォルトの名無しさん
05/02/09 14:26:11
ポート20をリッスン、認証できたら、ポート20のコマンドどうりに
ポート21でデータ転送。以上

297:デフォルトの名無しさん
05/02/09 15:11:36
私はCommonArchiverProjectのftp.dllを参考にしたことがあるなぁ。
バグがあって笑えたけど。

298:デフォルトの名無しさん
05/02/09 15:13:55
わらってはいけない。只で提供してるんだから。
金取ってるやつには罵詈雑言OK

299:デフォルトの名無しさん
05/02/09 15:16:10
いやぁ、使ってる人いないんだろうなぁと。<笑えた
尤も、作者に指摘メール送ったが黙殺されたので、本当のところは知らん。

300:デフォルトの名無しさん
05/02/09 17:03:27
#include <stdio.h>

void main(void)
{
int i;
char a[5];
for(i = 0; i < 5; i++){
printf("何か1文字入力する\n");
scanf("%c",&a[i]);
}
printf("%c,%c,%c,%c,%c\n",a[1],a[2],a[3],a[4],a[5]);
}

非常に簡単な質問で申し訳ないのですが…
このプログラムを実行するとforのi=2,i=4のときのscanfが飛ばされてしまいます。
その後の結果表示も何かおかしいのです。

自分なりに調べてはみましたが、一体何が悪いのかがわかりません。
コンパイラはBorland C++ Compiler 5.5を使っています。


301:デフォルトの名無しさん
05/02/09 17:06:20
改行コードもsacanfだな

302:デフォルトの名無しさん
05/02/09 17:37:54
void main(void)
{
int i;
char a[5]; // ←範囲は、0~4までで 5個
char b[1024];
for(i = 0; i < 5; i++){
printf("何か1文字入力する\n");
scanf("%s",&b); // バッファーフォローの危険性があり、実務だと駄目!
a[i] = b[0];
}
printf("%c,%c,%c,%c,%c\n",a[0],a[1],a[2],a[3],a[4]);
}

こんな感じだけど、入力は別関数を作ってね!

303:デフォルトの名無しさん
05/02/09 17:48:30
ださ

304:デフォルトの名無しさん
05/02/09 18:10:25
>>302
突っ込みどころ満載だな。
・バッファオーバフローの心配するなら指定子で制限しろ。
・配列のアドレスを渡すな。
・バッファーフォローなんて俺語を作るな。
・main()の戻り値を勝手にvoidにするな。

305:デフォルトの名無しさん
05/02/09 18:43:32
>>300
最後のprintfところでa[1]~a[5]になってるとこをa[0]~a[4]になおして、
それから一回目の入力で入れたい数字を全部連続でいれてみ?2468って感じで
最後の出力だけはきれいにでるとおもうよw

306:デフォルトの名無しさん
05/02/09 21:05:07
>>304
で、模範解答は?
文字列の読み込みって、簡単なようで難しいんだよね。

scanf を使って・・・・

307:300
05/02/09 21:22:25
300です。
皆さんレスありがとうございます。

あれからも考えてみましたが、やっぱりわかりませんでした。
aの配列というのが不味いのかと思って、a,b,c,d,eと定義してみましたが、これもまた同じ結果になってしまいます。
もうあきらめた方がいいんでしょうか。
バグの原因がわからないと、また再発させそうで非常に気になるんですが…

308:デフォルトの名無しさん
05/02/09 22:31:28
scanf使うのが悪い
fgetsしてsscanf使え


309:デフォルトの名無しさん
05/02/09 22:35:34
>>300
まず1文字目を入力した後、Enterを打つだろ。
そのEnterもscanfの%cで入力されているのだろう。
と、俺は予想した。
#include <stdio.h>
int main(void)
{
    int i;
    char a[5];
    for (i = 0; i < sizeof a; i++)
        scanf("%c%*[^\n]%*c", &a[i]);
        //%*[^\n]は'\n'が出るまで読み飛ばす指定
        //%*cは1文字読み飛ばし('\n'まで読み飛ばしたので当然'\n'を読み飛ばす事になる)
    printf("%c, %c, %c, %c, %c\n", a[0], a[1], a[2], a[3], a[4]);
    return 0;
}


310:デフォルトの名無しさん
05/02/09 22:41:35
>>300
301さんが解答ですよ。

  scanf("%c",&a[i]);

で一文字読み込んだとき、まだ標準入力のバッファには改行文字が残っているのです。
それが自動的に偶数回のscanf(...)の入力となっています。

  scanf("%c",&a[i]);
  fflush(stdin);

として標準入力のバッファをクリアしてあげれば、一文字ずつ入力できます。


311:デフォルトの名無しさん
05/02/09 22:47:26
>>310
fflushは出力バッファのフラッシュ用なんで残念!
stdinに対しては未定義り!

312:デフォルトの名無しさん
05/02/09 22:49:21
>>301-310
皆さんどうもありがとうございました。
おかげで解決しました。



313:デフォルトの名無しさん
05/02/09 22:53:31
#include <stdio.h>
#include <stdlib.h>

int GetStdinToInt()
{
  char buf[256];
  int result;
  char* check;

  while(1){
    fgets(buf, 255, stdin);
    result = (int)strtol(buf, &check, 0);
    if(check != buf) break;
    printf("もう一度入力してください:");
  }

  return result;
}


314:310
05/02/09 22:55:12
>>311
そのようですね。今調べて認識しました。

URLリンク(www9.plala.or.jp)

今回の解答は

URLリンク(www9.plala.or.jp)

に書いてありました。

315:302
05/02/09 23:02:16
>scanf("%s",&b);
scanf("%s",b); ←訂正すんまそ

最近、JavaとVBしかやってないから・・・・ (ーー

316:310
05/02/09 23:08:39
>>300

fflush(stdin)

のかわりに、

fseek(stdin, 0, SEEK_SET);

が動作保証されています。

でも、今回の場合は314で2番目のURLに書いてあることが一番いいかも。


317:310
05/02/09 23:11:50
失礼
fseek(stdin, 0L, SEEK_SET);
でした。

318:デフォルトの名無しさん
05/02/09 23:35:32
simpson法の中で関数を呼び出してその中で積分の計算を行うプログラムを作っています。
しかし、計算速度がものすごく遅いんですがなにかいい方法ありませんか?


319:デフォルトの名無しさん
05/02/09 23:37:51
で、今の計算機は?

320:デフォルトの名無しさん
05/02/09 23:50:30
>>318
難しいことやってるんだね、学生さん。
おいらにはよく分からないけど...。

URLリンク(www.mech.tohoku-gakuin.ac.jp)
にjavaだけれどコードがのってますよ。
良かったら参考にしてみたら。

321:デフォルトの名無しさん
05/02/09 23:57:32
>>320
thx
SSEつかって高速化図ってみます、、

322:デフォルトの名無しさん
05/02/11 00:36:27
C言語のバージョン教えてと言われた。
どうやって知ればいいんだろうか。

323:デフォルトの名無しさん
05/02/11 00:41:21
sにcharを足すstrcatってないの?

324:デフォルトの名無しさん
05/02/11 00:42:42
>>322
URLリンク(seclan.dll.jp)
の__STDC_VERSION__

325:デフォルトの名無しさん
05/02/11 01:14:37
>>323
ありませんよ。

Cで一般的に言われる文字列というものは、最後がヌル文字'\0'で終わることを前提
としています。提供されるシステム関数strcat()などもそうです。
一文字のcharはそういった関数で使用することはできません。

char dest[100];
char src1[] = "abc";
char src2 = 'x';
int len;

len = strlen(strcpy(dest, src1));
dest[len] = src2;
dest[len + 1] = '\0';

こんな感じですかね。もっとアクロバット的な方法もあるんでしょうが...。

326:デフォルトの名無しさん
05/02/11 01:49:10
int n = c;
strcat(s, &n);

327:デフォルトの名無しさん
05/02/11 02:14:49
>>326
関数内の自動変数の場合、
int n
の場合、cを代入した次のバイトがNULLである保証はありませんよ。

328:デフォルトの名無しさん
05/02/11 02:16:47
補足。
CPUのアーキテクチャによって異なります。
言語としてそういったことに依存すべきではないと言いたかったのです。

329:デフォルトの名無しさん
05/02/11 02:50:54
>>327
ん? cは1バイトだから他の3バイトは当然0になるでしょう。 しかしこれは
endianによっては右に詰まってだめだと思うので >>328は正しいと
思うけど。

ちなみにこんなのはどう?
sprintf(s, "%s%c", s, c);


330:デフォルトの名無しさん
05/02/11 06:51:06
>>329
未定義

>>326
char s2[] = {c, '\0'};
strcat(s, s2);でいいじゃん。

C99ならstrcat(s, (char []){c, '\0'});って書ける筈だけど。

331:デフォルトの名無しさん
05/02/11 10:17:54
私はこんな幹事かな。
sprintf(strchr(str, '\0'), "%c", ch);
或いはこう。
char * p = str + strlen(str);
p[0] = ch;
p[1] = '\0';

332:デフォルトの名無しさん
05/02/27 16:56:10
すみません、妙な質問で恐縮ですが、どなたか教えてください。

sprintf() の s ってどういう意味ですか?f は format の意味だと思うのですが。

333:デフォルトの名無しさん
05/02/27 16:59:08
stringじゃない?

334:デフォルトの名無しさん
05/02/27 17:01:38
sはsecond。fはfirst

335:デフォルトの名無しさん
05/02/27 18:04:22
string ですか。ありがとうございました。
scond ですか(ry

336:デフォルトの名無しさん
05/02/28 12:51:53
>>332
printf()「系」とかssanf()「系」とか言う言葉があるよ。
先頭の's'はstring、'f'は自分でオープンしたファイル、付かないものは対象がstdinか
stdout。結構系統立てられているんですよ。

337:336
05/02/28 12:53:07
メンゴです。
一行目のssanf()はscanf()でした。

338:デフォルトの名無しさん
05/02/28 14:16:48
>>336
さらにva_listを引数に取るvprintf/vscanfも有る。当然fとsも有る。
vscanf系はC99で追加されたものだけど。

339:デフォルトの名無しさん
05/02/28 18:51:54
springfというのもある

340:デフォルトの名無しさん
05/02/28 22:45:28
さらに最新最強はsnprintf。 渡したchar *のサイズを2つ目の引数で指定でき、
そのサイズを超えて書かないことが保障されているのでやや安全。

341:デフォルトの名無しさん
05/03/02 16:40:40
アドレスに関する質問。
型は不明で、要素一つのサイズは分かってる場合。

次の要素にアクセスする方法を教えて下さい。
または次の要素へのアドレスを取得する方法。


342:342
05/03/02 16:42:50
サイズがBYTEだってことに気づかなかった....。
解決しました。

343:デフォルトの名無しさん
05/03/09 14:33:38
POINT point[3] = { {0,0} , {1,0} , {0,1} };
っていう初期化はできるんですが

point[3] = { {0,0} , {1,0} , {0,1} }
という風に値を入れることが出来ません
配列全体に値を入れる方法は無いんですか?

344:デフォルトの名無しさん
05/03/09 16:00:29
>>343
配列に代入はできません。
精々コピー用の関数を用意するのが関の山です。
要素数が3で固定ならば、構造体にしてしまえば(直値ではありませんが)代入できなくもありません。


345:デフォルトの名無しさん
05/03/09 16:10:27
>344
関数でもつくってそれで入力するようにします
ありがとうございました。

346:デフォルトの名無しさん
05/03/10 00:43:33
Cって、こういうとこアフォだよなあ

347:デフォルトの名無しさん
05/03/10 19:02:05
やっぱりRubyがいいね

348:デフォルトの名無しさん
05/03/13 17:13:30
cでコンパイルする際に

windres: can't open `obj/EK-MAMEko/ui/mame32k.res' No such for directory
make: *** [obj/EK-MAMEko/ui/mame32.res] Error 1

こういうエラーが出て困ってるんだけど
これってどういう意味かわかる?

349:デフォルトの名無しさん
05/03/13 17:14:00
age

350:デフォルトの名無しさん
05/03/13 18:48:41
>>347
いや、Rubyは問題外。

351:デフォルトの名無しさん
05/03/17 00:52:33
変数を入れ替えるときに別の変数を用意せず、

X = X ^ Y, Y = X ^ Y, X = X ^ Y;

とするのがよくないのはなぜ?

352:デフォルトの名無しさん
05/03/17 00:56:22
>>351
数値以外には使えない
XとYが同じ変数を指していると上手くいかない

353:351
05/03/17 01:17:15
>>352
なるほど。
これをプリプロッセスでやって構造体なんかを渡しちゃうとマズーだ。
アリガト。

354:デフォルトの名無しさん
05/03/22 21:55:06
new演算子で作ったオブジェクトをdeleteした後に
デストラクタでdeleteすると何か問題ありますか?

355:デフォルトの名無しさん
05/03/22 23:09:33
mallocで確保した領域をfreeで開放しますが、
システムはどのようにして、はじめに確保した領域を知ることができるのでしょうか。

356:デフォルトの名無しさん
05/03/23 01:23:39
>>354
deleteしたら、0を入れておけば大丈夫。

>>355
malloc()で戻されたポインタの指すメモリの直前辺りに管理情報を埋めておくのが一般的。

357:デフォルトの名無しさん
05/04/03 14:07:55
配列同士の数値の比較をしたいのですが、下記のようだとうまくいきません。
どのようにすればよいのでしょうか?
for(i=0;i<5;i++)
for(j=0; j<5; j++)
if(group[i] == group[j] && i != j) count[i]++;

358:デフォルトの名無しさん
05/04/03 15:10:03
>>357
j = i

359:デフォルトの名無しさん
05/04/03 15:22:36
>>357
配列の同じインデックスを持つ要素同士を比較したいのであれば、単純な(一重の)ループでいい。
つーか、>357では日本語の説明が足りんし、コードがおかしいし、何がしたいのか判らんのだが。

360:デフォルトの名無しさん
05/04/04 00:24:27
すみません。初歩的な質問をさせていただきます。

char *func1(){
 return "a";
}

char *func2(){
 char *s = "a";
 return s;
}

こんな2つの関数があったとして、これらが関数の呼び出し元に返ってきた際に
戻り値のポインタが正しい場所を指し示すことはどこまで(いつまで)保障できるんでしょうか?
func1は保障できる、func2はできる、それとも両方できない/できる、どこまでなのか…等。
また、私の勉強不足のせいで、両者のメモリ上での違いがいまいちはっきりしてません。

一応どちらでも動作するにはするんですが、いつか不正な参照とかで
落ちちゃうんじゃないかと気になって怖くて夜も眠れません。

参考になるサイトを教えていただけるだけでも結構ですのでよろしくお願いします。

361:デフォルトの名無しさん
05/04/04 01:05:29
規格ではどうか忘れたけど、たいがいいけるはず。
どうしても心配ならstatic const char ret_str[] = "a";とかすれば?
あとchar *じゃなくてconst char *を使え。

362:デフォルトの名無しさん
05/04/04 01:08:07
>>360
定数(リテラル)の寿命はプログラムの開始から終了まで。
関数内で宣言されたauto変数の寿命は、関数の開始から終了まで。

char *func1(){
 return "a"; /* "a" を指すポインタを返している */
}
char *func2(){
 char *s = "a"; /* ポインタ s を "a" を指すポインタで初期化 */
 return s; /* ポインタ s の値、つまり "a" を指すポインタを返している */
}

つまり、どっちも同じ。
リテラルはいつでもどこからでも参照出来るので、戻り値を使ってても大丈夫。

363:360
05/04/04 02:05:28
>>361-362
ありがとうございます!だいぶスッキリしました。
リテラルに関しては参照先が不正な値になるんじゃないかとかいう
心配は無用なわけですね。逆の場合(変数、関数のポインタ)は気をつけろと。

すみません。あとここからもう一段階お願いします。
実は言うと今、Unix系ソフトの移植作業をやってまして
こいつらと同等の動作をするものを作りました。

char *dirname(char *path);
char *basename(char *path);

basename()はパス名からディレクトリを除いた部分(ファイル名)を返せばいいので
引数のポインタをそのまま使い回してreturn path+pos;のようにして返してます。

dirname()の方は引数で与えられたパス名からファイル名を除いたものを返すものなので、
関数内でdir[MAX_PATH]のように宣言した配列に、引数の文字列からファイル名部分を
除いたものをstrncpyでコピーなどして、最後にdir(先頭アドレス)を戻り値にしてます。
(ちなみにさっきの質問は"."「カレントディレクトリ」を返す場合でした。)

長すぎるのでまとめると、
・basename()の戻り値は呼び出し先のローカル変数とは無関係である。
・dirname()の戻り値は呼び出し先のローカル変数に依存している。

この場合だと、dirで確保していたアドレスは戻り先で参照しても安全なのでしょうか?
ちゃんと動くし、自分でも大丈夫だと思ってたのに警告が出たので不安になりました。

やたら長くてすみません。何かこれより良い実装方法がもしあればご教授願います。

364:360
05/04/04 02:14:47
何度もすみません。つまりさっき私が言ったdirname()の実装は

char *func2(){
 char *s = "a"; /* ポインタ s を "a" を指すポインタで初期化 */
 return s; /* ポインタ s の値、つまり "a" を指すポインタを返している */
}

この場合と同じと考えていいんでしょうか?ってことですね。
私の目には全く同じものに映るのですが、間違いありませんでしょうか。

365:デフォルトの名無しさん
05/04/04 02:15:23
floatがもてる最大値はどのように調べればよいのでしょうか?

366:デフォルトの名無しさん
05/04/04 02:30:48
>>363-364
const char *func3(void){
const char s[] = "a";
return s; /* ローカルな配列 s へのポインタを返す */
}

const char *p;
p = func(); /* 0, func() の s へのポインタを受け取る */
printf("%p\n", p); /* 1, これは構わない */
printf("%s\n", p); /* 2, これは駄目 */

0 は何ら構わない。戻ってきたアドレスをコピーしているだけ。
1 も何ら構わない。コピーしたアドレスを表示しているだけ。

2 は駄目。アドレスの先を参照してしまっているから。
何故参照してはいけなかというと、アドレスの先にある func3() の s の寿命は、
func3() を抜けた時点で既に尽きてしまっているから。

func2(), func3() は全然違う関数。

367:デフォルトの名無しさん
05/04/04 02:35:17
>>365
float.h にある FLT_MAX マクロで定義されてる。

#include <stdio.h>
#include <float.h>
int main(void)
{
 printf("%f\n", FLT_MAX);
 return 0;
}

368:デフォルトの名無しさん
05/04/04 02:50:42
>364
ダメ。変数の寿命について学んでください。

1.関数の引数を変える。
void dirname(char *dest,int dest_size,const char *path)

2.静的に保持する。使用に若干注意が加わる
static char dir[]

3.動的に確保する。呼び出し側に解放義務が発生する
char *dir = malloc()

369:デフォルトの名無しさん
05/04/04 03:05:49
>>367
thx
limit.hしか知らなかった

370:360
05/04/04 03:13:01
そのまま貼っちゃいます。今はこんな状態です。

char* dirname(char* path)
{
  int pos = strlen(path)-1;
  int lastPathSepFoundPos = -1;
  static dir[MAX_PATH]="";
  while(pos >= 0) {
    if (path[pos] == '/' || path[pos] == '\\') {
      lastPathSepFoundPos = pos;
      break;
    }
    else pos--;
  }
  if (lastPathSepFoundPos == -1) return "."; // current dir
  else{
    strncpy(dir,path,lastPathSepFoundPos);
    dir[lastPathSepFoundPos] = 0;
    return dir;
  }
}

static dir[MAX_PATH]="";をchar dir[MAX_PATH]にすると
→警告「ローカル変数またはテンポラリのアドレスを返します」
となってました。今考えてみれば当然ですよね。。

>>368
どうもです。ちょうど昨日、その2を回避策としてやってみてたとこでした。
その注意というのは関数へのアクセスが同時に起こるような場合でしょうか?

条件コンパイル(#ifdef-#endif)等が面倒になりそうですが、
1の方法が一番簡単そうなので、その方向でやってみることにします。

371:デフォルトの名無しさん
05/04/04 03:14:54
↑static char dir[MAX_PATH]="";の間違いです。

372:デフォルトの名無しさん
05/04/04 12:12:39
strrchr 使えば簡単にみえるな・・・

373:デフォルトの名無しさん
05/04/04 16:49:40
すみません最近C++触ったばかしですみませんが

class auのコントラクタ関数
au(string s) : enr(s) {}について
文字列をsに代入し enrを生成する時にsを代入すると読めるのですが
なぜ au(string s) { enr(s); }とできないんですか?

個人的に関数内容 { }内 は動作命令のみの記述と解釈すれば
au(string s) { enr = s; }
はenr = s;という動作命令であるから適応であるが
{ enr(s); }・・・であるから不適と思ってしまうのですが・・

書いててよくわからなくなってきた・・
au (string s) : enr(s) {}について
なぜ : で区切るのかと enr(s)はなぜ{}内に記述してはいけないのかについて詳しくお願いします

374:デフォルトの名無しさん
05/04/04 17:09:15
>>373
:の後は初期化。{}の中だとメンバ変数への代入になってしまう。

例えば、
class foo {
const int bar;
foo() : bar(0) {}
};
とした場合、この例のように初期化はできるが、
class foo {
const int bar;
foo() {bar = 0;}
};
このような代入はできない。

375:デフォルトの名無しさん
05/04/04 17:33:16
>>374
全て解決できました。
どうもありがとです

376:デフォルトの名無しさん
05/04/19 19:50:11
共用体ってどういうときに使うんですか?
また利点とかあるんですか?

377:デフォルトの名無しさん
05/04/20 00:05:37
すみません。教えてください。
下記のようなプログラムを書くと、結果に必ず0.0が混ざってしまい、困っています。
乱数を3つ表示させたいのですが、0.0を含まないようにするにはどうしたらよいのでしょうか?

#include <stdio.h>
#include <stdlib.h>
#include<time.h>
#define N 3
int main(void)
{ int i,j=0,check;
double data[N],dia[N],tmp;
srand((unsigned)time(NULL));
printf("\n乱数のつもり:\n");
for (i=1; i<=N; i++)
{data[i]=rand()%100+(double)rand()/32768.0;}
/* 並替えの計算 */
for (i = 1; i < N - 1; i++)
for (j = i + 1; j < N; j++)
if (data[j] < data[i]) /* <: 昇順, >: 降順 */
{ tmp = data[i];
data[i] = data[j];
data[j] = tmp;};
for (i = 0; i < N; i++)
printf("%.1f ", data[i]); /*並替えデータの表示*/
}

378:デフォルトの名無しさん
05/04/20 00:47:24
>>376

それくらい調べろよ。

379:デフォルトの名無しさん
05/04/20 01:25:42
>>376
メモリの節約
同じメモリブロックを複数の型として解釈したい時

380:デフォルトの名無しさん
05/04/20 11:52:18
>>377
取り敢えず落ち着け。
深呼吸でもした後、data[] の添え字の範囲が
0~N-1 だと言うことを思い出せ。

381:デフォルトの名無しさん
05/04/20 13:25:48
>>376
通信などで、整数型や実数型をバイト列と相互変換したい場合、
ポートアクセスなどでビットフィールドとバイト列を相互変換したい場合などに使う。
メリットは、他の方法に較べて簡便に書けること。
デメリットとしてよく言われる非互換性については、元々汎用的でないコードを書く場合には無視できる。
#勿論、それ相応のコメントは必要。

382:デフォルトの名無しさん
05/04/23 00:09:57
C、C++ある程度覚えるまで、どのくらい掛かった?今から、勉強しようと思うのですが、C→C++→C#か、Javaって感じに逝こうかと思うのですが、C++から移行した人、する人は、C#か、Javaどっち盗ります?←煮たスレあるけどノリで…ゴメソ

383:デフォルトの名無しさん
05/04/23 00:19:39
>>382
無意味なアンケートするな。

384:デフォルトの名無しさん
05/04/23 10:31:57
無意味っていいよね。
まぁ答えてやんなよ。発想の無い、IT土方プログラマーの行く末までを……ハァー 


385:デフォルトの名無しさん
05/04/23 12:04:48
なんでこう勉強する前にウダウダ人に聞くやつが多いんだろう

386:デフォルトの名無しさん
05/04/23 12:20:20
>何でこう勉強する前にウダウダ人にきく奴が、多いのだろう 
って、自分も聞いてるじゃんWWW プギャー、と云ってみたくなる。まあ、オイラは聞かなかった、お陰でプログラマーなんかになってしまった訳だが…ハァー

387:デフォルトの名無しさん
05/04/23 12:23:43
ageんなやボケがあああああ、と自分に云ってみるテst
すまんです

388:デフォルトの名無しさん
05/04/26 11:13:11
  ∧_∧
 ( ´∀`) < ぬるぽ

389:デフォルトの名無しさん
05/04/27 10:54:11
1+2+3+・・・+N を計算する関数を作成せよ。

390:デフォルトの名無しさん
05/04/27 11:48:18
>>389
int f(int N){return((1+N)*N/2);}

391:デフォルトの名無しさん
05/04/27 11:57:21
1/2/3/・・・/N を計算する関数を作成せよ。

392:デフォルトの名無しさん
05/04/27 12:05:48
>>391
int f(int N){return0;}

393:デフォルトの名無しさん
05/04/27 12:45:24
>>390
感動した
>>392
ワロタ

394:デフォルトの名無しさん
05/04/28 04:36:53
>>391
double f(int N){double x=1.0;if(N>1)while(N)x*=(double)N--;return 1.0/x;}

395:394
05/04/28 04:42:40
あんま変わらんけど、こっちの方が良かったかな…?
double f(int N){double x;for(x=1.0;N>1;N--)x*=(double)N;return 1.0/x;}

396:デフォルトの名無しさん
05/05/04 18:36:51
スレリンク(news4vip板:18番)
↑exitするならfcloseもfreeもしなくていいんだけど
  ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
ってあるんですが、そうなんですか?
ファイルディスクリプタはプログラム終了時に閉じられるとしても
メモリリークっすよねコレ

397:デフォルトの名無しさん
05/05/04 19:00:23
>>28
ガッ

398:デフォルトの名無しさん
05/05/04 19:58:54
>>396
大丈夫。真っ当なOSならアプリケーション終了時にきちんと開放する。

399:デフォルトの名無しさん
05/05/04 20:06:09
>真っ当なOSなら


400:デフォルトの名無しさん
05/05/04 22:08:18
OSが真っ当かどうかに関わらず真っ当な規格合致処理系なら、
exit()を呼んでいなくてもmain()からreturnすればファイルは閉じられる。
main()でのreturnはexit()の呼び出しと等価とも書かれている。(他の関数からmain()を呼んだ場合は別だが)

しかしfree()の方にはそのような記述は見当たらない。
(free()を呼ばないで終了するとどうなるかということは書いていない)

401:デフォルトの名無しさん
05/05/04 22:14:15
>>400
>(free()を呼ばないで終了するとどうなるかということは書いていない)

free() を読んで終了すればどうなるかということも書いていないけどな。


402:デフォルトの名無しさん
05/05/04 22:23:14
またこの話題か
好きにすれ

403:デフォルトの名無しさん
05/05/04 22:31:48
gotoを使うのは不味いのでしょうか?
どなたかおすえてください

404:デフォルトの名無しさん
05/05/04 22:57:09
Cで質問です。
変数nの値が??のとき、filename??という名前のファイルを開きたい
という場合に、fopenの第1引数にはどのように記述すればよいでしょうか?
先にsprintfを使えばできるようですが
直接引数の部分に記述して何とかする方法がないかと思いまして。

405:デフォルトの名無しさん
05/05/04 23:19:00
>>404
char *filename(int n) { static char buf[100]; sprintf(buf, "filename%d", n); return buf; }

fopen(filename(n), ... )



406:デフォルトの名無しさん
05/05/04 23:26:43
>>405
なるほど!その手がありましたか!
おめでとうございます!ありがとうございます!


(ノ´Д`)ノ 彡┻┻

407:デフォルトの名無しさん
05/05/05 19:22:25
次にこんなことをしてハマると見た。
rename( filename(1), filename(2) ); // filename.1 を filename.2 にバックアップ

408:デフォルトの名無しさん
05/05/05 23:19:39
>fopenの第1引数
そもそもパスとか編集しなくていいのか?

素直に
>先にsprintfを使え

409:デフォルトの名無しさん
05/05/05 23:28:04
そこでC++ですよ。
std::string filename(int n) {return "filename" + boost::lexcal_cast<std::string>(n);}

410:デフォルトの名無しさん
05/05/09 09:50:14
C言語をはじめたばかりであまりわからないのですが、
ビットシフトはなんの役に立つのでしょうか?

411:デフォルトの名無しさん
05/05/09 09:51:19
URLリンク(p6222ed.kyotac00.ap.so-net.ne.jp)

うはっwwwwwwwwwwwwwww

っうぇwwwwww
っうぇうぇwww
wおkwwwwうはっwww
おkwww

っwwwwww

うぇwww


412:デフォルトの名無しさん
05/05/09 10:07:08
URLリンク(EAOcf-526p83.ppp15.odn.ne.jp)
おkwwwwwwwwwwwwおkうぇおkwwwwww
うはっwwwwwwwwwwwwwwwwwwwwwwwwwwwww
うはっうはっwwwwwwwwwwwwwww
wwwwwwwwwwwwっっうぇうぇ
うはっ

413:デフォルトの名無しさん
05/05/09 10:14:46
URLリンク(pdf791d.tokynt01.ap.so-net.ne.jp)

wwwおkwwwwwwうぇwwwwwwwwwっうぇ

おkwwwっうぇうはっwwwwうぇwww

wっうぇうはっwwwwwwwwwwwwwwwwww

414:デフォルトの名無しさん
05/05/10 16:35:01
>>410
ビットシフトしたいときに役に立つ

415:デフォルトの名無しさん
05/05/10 18:01:05
あと、2進数の桁をずらしたいときにも役に立つね。

416:デフォルトの名無しさん
05/05/10 18:29:55
>>410
任意の上位Nビットを取り出したいとかその逆をしたいときとかに。
DWORD dw = 0x12345678;
WORD wHigh = dw >> 16; // 0x1234
WORD wLow = dw & 0xffff // 0x5678
DWORD dw2 = dw << 16 | wLow // 0x12345678


417:デフォルトの名無しさん
05/05/11 18:16:54
<質問>
ピクチャポックに表示した画像をマウスドラッグで範囲選択します。
その選択範囲をマウスのドラッグ中、リアルタイムに枠線で囲みたいのですが
どういう処理が一般的でしょうか?

DrawLineで線を書いたり消したりとかは、おかしいですよね?

418:デフォルトの名無しさん
05/05/11 18:53:11
>>417
>>1-10 を見ろ。
回答が欲しければ Windows 系のスレに行くんだな。

419:デフォルトの名無しさん
05/05/11 20:15:27
XOR

420:417
05/05/11 23:15:27
すまそん。
他で聞いてきます・・・。(・・`)

421:417
05/05/12 00:23:25
>419
もしかして、私へのヒント?
そうだったら、ありがとうございます。

ビット反転させたらいいのかなー。
とりあえず、C#の過去ログ見てます。


422:デフォルトの名無しさん
05/05/12 10:11:02
int main(void)
{
double i;

for(i=1.0; (int)i<=9; i=i+0.1) {
printf("%d", (int)i);
printf("%lf ", i);
}

return 0;
}
iが5.000000のとき(int)iがなぜ4になるのか分かりません。
小数部を切り捨てて5になると思うのですが。

423:デフォルトの名無しさん
05/05/12 11:35:49
>>422
誤差の累積。誤差について調べられたし。

424:デフォルトの名無しさん
05/05/13 16:14:34
>>417
まさしくそれ向けの関数がMFCにあった気がする。

425:デフォルトの名無しさん
05/05/13 16:21:49
MFCつーか、、、APIであるけど
今はもうXORの時代じゃないのかもなあ

426:デフォルトの名無しさん
05/05/13 16:26:18
いちおー書いておくか
APIなら
DrawForcusRect
MFCだと
CDC::DrawForcusRect

それよりも、CRectTracker クラス使ったほうがいいかも

427:426
05/05/13 16:39:17
ってここC#のスレだった・・・
スレタイで半角#使ったのか・・・

428:デフォルトの名無しさん
05/05/14 07:08:29
>>427
気にするな
ごみスレだ

429:デフォルトの名無しさん
05/06/28 09:16:29
LSI C-86でコンパイルしてるんですが
unknown dimensionっていうエラーは
どんな間違いをしてる可能性があるんですか?

430:デフォルトの名無しさん
05/06/28 09:45:41
>>429
>どんな間違いをしてる
コンパイラの選択。

まぁ、恐らくは二重以上の配列で、要素数の指定が漏れているんだろうけど。
int func(int a[][]);
とかね。

431:デフォルトの名無しさん
05/06/28 10:21:35
二次元と表現せずに二重と表現するのが
Cらしいなw

432:デフォルトの名無しさん
05/07/05 16:40:43
クラス継承で教えて
class AandB : public A , public B
{

}
というのを作ろうとしたら
Aのメンバー関数で
A::data()

Bのメンバー変数で
char * B;;data
と名前が衝突していた.

B::dataのみにアクセスするにはどうすればいいの?

433:デフォルトの名無しさん
05/07/05 17:26:48
>>432
B::dataでダメなら、using

434:デフォルトの名無しさん
05/07/05 21:16:22
うまくいった
class AandB : public A , public B
{
AandB(){
this -> B::data
}
}
でアクセスできた

もうひとつ疑問が
class AandB : public A , public B
{
class B *pB;
AandB(): pB(&B)
{
}
}
pBにポインターの値を代入したいんだけどできない

435:デフォルトの名無しさん
05/07/05 22:17:22
>>434
class AandB : public A , public B
{
  class B *pB;
  AandB(): pB(static_cast<B *>(this))
  {
  }
};
キャストは要らないが一応書いておいた。

436:デフォルトの名無しさん
05/07/10 11:50:07
namespace your {
  struct girlfriend {
    void lips();
  };
}

namespace my {
  struct girlfriend {
    static void lips();
  };
  class wife : your::girlfriend {
  public:
    void kiss() { girlfriend::lips(); }
  };
}

さて、wife::kiss() するとgirlfriend::lips()によって
奪われるのは基底クラスの your::girlfriend::lips() か、
はたまた同じnamespaceにある my::girlfriend::lips() なのか?

VC7, gcc3.1 では基底クラス your:girlfriend::lips() で、
BCC564では 名前空間を優先して my::girlfriend::lips() でした。

どっちがせーかいでしょう? 
雰囲気からして基底クラスを採るのがスジっぽいけど。 


437:デフォルトの名無しさん
05/07/10 14:17:24
みなさん、コンパイラなどする時はコマンドプロントからやっていますか?
それとも編集もまとめて出来るフリーツールなど使ってらっしゃいますか?

まだプログラミング始めたばかりなんですが、コマンドプロントの方法もやはり覚えといた方がいいんですかね?

438:デフォルトの名無しさん
05/07/10 14:31:47
プログラムを学習する目的が限定されていて、コマンドプロンプトを使わなくて済むなら、
覚える必要はない。
授業でどうしてもやらなきゃいけないとか。

プログラミング全般に詳しくなりたいなら、覚えておいた方がいい。


439:デフォルトの名無しさん
05/07/10 19:03:07
学習目的でプログラムを組む際、教科書によってはコマンドプロンプトを前提としているものがある。
だから、教科書しだいかな。
個人的には、ツールを組み合わせることが楽なので、覚えるといいとおもう。

440:デフォルトの名無しさん
05/07/10 20:20:05
簡単な、初級プログラムというのはどうしても、コマンドラインを使った処理、
入出力になるからな。憶えるべきというか、憶えないと学習効率が悪いと思うぞ。
世の中に出ている初級者用のC言語情報なんて、ほとんどがコマンドラインを
前提としているからな。

441:デフォルトの名無しさん
05/07/10 22:20:27
やはりそうですか
分かりました、ありがとうございました。

442:デフォルトの名無しさん
05/07/11 23:02:56
IDEかmakeかって話だろ。
そんなの当面どうだっていいだろ。

443:デフォルトの名無しさん
05/07/16 19:15:31
質問
int a = 1;
if ( a == (int)0) {
...
}
のように、キャストした方がいいの?

444:デフォルトの名無しさん
05/07/16 21:53:36
いらない

445:デフォルトの名無しさん
05/07/16 22:06:14
>>443
ただの整数は元からint型。

446:デフォルトの名無しさん
05/07/20 17:02:19
この速度ならぬるぽ

447:デフォルトの名無しさん
05/08/09 01:41:05
Cを使った開発で質問させて頂きたいのですが

ありがちなDBを使った業務システムを開発するときに
MFCと.netフレームワークを比べると
どちらの開発効率が上でしょうか。

漠然とした質問ですが
主観等々で構いませんので、ご意見いただけますでしょうか。

448:デフォルトの名無しさん
05/08/09 01:59:47
MFCも.netもCじゃなくC++だが。

449:デフォルトの名無しさん
05/08/09 02:00:46
ありがちなDBを使った業務システムは開発効率より優先する
ものがあるんでねぇ?
oo4o+vbに1票

450:デフォルトの名無しさん
05/08/09 09:50:43
スレ違いだったらすみません。
自分用にデバグしやすいmalloc/realloc/freeを実装してみようと
思っていますが何を参考にすればいいかわかりません。
シンプルで小さい実装のソースがあったらURLを教えて下さい。


451:デフォルトの名無しさん
05/08/09 11:50:46
void *my_malloc(size_t size) {
  void *p = malloc(size);
  ...hoge
  ...fuga
  return p;
}
みたいのじゃだめなのか。
メモリアロケーションを実装するのは大変だと思うが。

452:デフォルトの名無しさん
05/08/09 13:21:22
#define malloc my_malloc

453:デフォルトの名無しさん
05/08/09 14:20:45
すみません、質問が悪かったですね。
端的に、mmap を実装してみたいんです。
ある組込の環境で、malloc がかなり遅い
環境があるんですが、自分で実装してみたら
それを速くできるのか、それとも自分だともっと
遅くなってしまうのか、興味があったのです。



454:デフォルトの名無しさん
05/08/09 16:08:50
mmapの実装って環境依存じゃないだろうか。ソースならunix系オープンソースosのを
見ればいいだろうけど、参考にはならないような。それはそのままハードorOSの性能
くさいし。欲しいのは多分メモリプールだろうからやるとしてもmallocをラップして
プールするのがいいんじゃないかと。
おもろい文章
URLリンク(www-6.ibm.com)

455:デフォルトの名無しさん
05/08/09 19:51:06
>>453
URLリンク(www.uclibc.org)
あたりの実装は参考になるんじゃないかな。 MMUあり、無しの両方に対応する実装がある。


456:デフォルトの名無しさん
05/08/15 12:17:32
あるファイルが存在するかどうかを確認するにはどうしたらよいのでしょうか?
出来るだけ環境に依存しない方法がよいのですが

457:デフォルトの名無しさん
05/08/15 13:06:53
>>456
環境依存しないと言うことなら、存在する≒読めるということで
fopen(targetFile, "r")が成功するかどうかで判断するのが無難。

まぁ、大抵の環境でaccess()かstat()はあると思うがな。
#某環境では、access()がfopen()で実装されているのは内緒。

458:デフォルトの名無しさん
05/08/18 12:41:09
K&Rにmalloc/freeの実装が乗ってる。


459:デフォルトの名無しさん
05/08/19 23:34:15
C言語一通り学んだらDirextXとWINAPIどっちやればいい?

460:デフォルトの名無しさん
05/08/20 00:28:38
>>459
C++
特にDirectXをやるのなら絶対。WinAPIをやるのでもなるべく。
そもそもDirectXはライブラリなどで隠されていない限りある程度WinAPIで下準備が要るから、
結局WinAPIの知識が要る。

461:デフォルトの名無しさん
05/08/31 11:32:56
a, bが変数だとして(…の中で変更される可能性あり)、

(1)
if (a == b) {
 while(a == b) {
  …
 }
 // ★
}


(2)
if (a == b) {
 do {
  …
 } while (a == b) ;
 // ★
}

は同じ意味ですか?

今(1)のコードで★部分にコードを追加したいので、
(2)に変えても問題ないか知りたいです。


462:デフォルトの名無しさん
05/08/31 11:34:53
while(a == b) {
 …
}
if (a == b) {
 // ★
}
のほうがまだ読みやすくない・・・?

463:デフォルトの名無しさん
05/08/31 11:39:19
>>461
同じだと思う。

>>462
それは意味が変わってる。

464:デフォルトの名無しさん
05/08/31 12:01:38
>>461
積極的に(2)に変えたい理由は?
別に(1)のままでもいいと思うのだけど。

465:デフォルトの名無しさん
05/08/31 14:03:12
最初に一回無駄な比較が増える

466:デフォルトの名無しさん
05/08/31 14:12:57
>>462
>461 (…の中で変更される可能性あり)

467: ◆cFJoQcQH2U
05/08/31 14:16:11
「神戸 330 ふ 1234 この車はどうのこうの(箇条書き)」
sscanfで、上のような文字列を読み取るのに、
"%s %d %s %d %s"を使っているのですが、最後の備考欄に
空白文字が入っているとすべてが読み取れません。
「残りすべての文字列」というマークはありますか?
WinXp,VS.netです。

468:デフォルトの名無しさん
05/08/31 15:15:43
>「残りすべての文字列」というマークはありますか?
そんなものは無い。
fgetsで行末まで読んで、読んだ文字列を変換するのが良い

469: ◆cFJoQcQH2U
05/08/31 15:25:43
そうですか・・・ありがとうございます。
fgetsで読んで、4つ目の改行文字以降を読み取ることにします。

470:デフォルトの名無しさん
05/08/31 15:28:51
"%s %d %s %d %[\x01-\xff]"

471:デフォルトの名無しさん
05/08/31 21:45:00
条件演算子の? : は右結合ということですが、
a() { printf("a\n"); return 0; }
b() { printf("b\n"); return 0; }
c() { printf("c\n"); return 0; }
d() { printf("d\n"); return 0; }
e() { printf("e\n"); return 0; }
f() { printf("f\n"); return 0; }
g() { printf("g\n"); return 0; }

main() {
a() ? b() ? c() : d() : e() ? f() : g();
}

とした場合、結果が
a
e
g
となりました。

? : の右結合とは、どの部分に掛かってるんでしょうか?


472:デフォルトの名無しさん
05/08/31 21:46:37
↑結果を見ると左結合に見える、ということです。

473:デフォルトの名無しさん
05/08/31 21:52:57
>461

なぜ(2)の形にしたいのかがわからない。
必ず一回余分な判定が入るのが嫌程度なら(1)の書き方をお勧めする。
上から下への流れで読みやすい。

(2)だとループ条件がループの終わりにならないと分からないので
一部の人間からは嫌われてたりする。

自分は(1)はだね。

474:デフォルトの名無しさん
05/08/31 21:55:04
参考に
void loopfunc(void)
{
clock_t s[2], e[2], t[2];
int i, j;int a, b;
 s[0] = clock();
 for(j=0;j<100000000;j++){
  a = 4568992;
  b = -5621984;
  if(a==b){
   while(a==b){
    a %= b;
    a *= b;
   }
  b %= a;
 }
 e[0] = clock(); t[0] = e[0] - s[0];
 s[1] = clock();
 for(j=0;j<100000000;j++){
  a = 4568992;b = -5621984;
  if(a==b){
   do{
    a %= b;
    a *= b;
   }while(a==b);
  b %= a;
 }
 e[1] = clock(); t[1] = e[1] - s[1];
printf("t[0] = %d\nt[1] = %d\n", t[0], t[1]);
}

475:デフォルトの名無しさん
05/08/31 22:08:54
>>474
if(a==b)の括弧が閉じてないので修正しましたが、
うちの環境では

t[0] = 2593
t[1] = 2384

(2)が速いみたいですね。


476:デフォルトの名無しさん
05/08/31 22:10:32
>>471

C言語の有名なバグです。
条件演算子の仕様的にも左結合で合ってます。

477:デフォルトの名無しさん
05/08/31 22:16:06
>>476
違うよー
1?2?3:4:5
と書けるのは右結合だから。(結果は3)

>>471
結合規則と評価順序は関係ないよ。

478:デフォルトの名無しさん
05/08/31 22:18:25
つまり右結合の掛かる場所は、括弧で括ると
1?(2?3:4):5
こういうことね。

479:デフォルトの名無しさん
05/08/31 22:21:11
>>478
し、知らなかった・・
これでもC言語暦10年なんだが。

480:デフォルトの名無しさん
05/08/31 23:21:11
main(argc, argv)
int argc;
char *argv[];
{

↑↓

main ( int argc, char *argv )
{

どうちがうの??

481:デフォルトの名無しさん
05/08/31 23:35:22
上 K&R
下 ANSI

上は古い書き方で、普通は下の書き方を使う。
意味上の差はない。

482:デフォルトの名無しさん
05/08/31 23:37:48
と思ったが、よく見ると下のargvがchar*になってやがる。

それ以外は同じ。
あと、戻り値の型もちゃんと明示したほうが良い

483:デフォルトの名無しさん
05/08/31 23:51:47
cdeclなら別にどうでもいいよ

484:デフォルトの名無しさん
05/09/01 00:00:31
int func(float a)
{
return sizeof(a);
}

int func(a)
float a;
{
return sizeof(a);
}
では違う結果を返すコンパイラもある。

485:480
05/09/01 00:37:29
ありがとうございます。

したのargvに[]が無いのは転記漏れでした。申し訳ない。



486:デフォルトの名無しさん
05/09/01 00:38:47
なんで?
ビット長が違う環境とか?

487:デフォルトの名無しさん
05/09/01 00:44:35
>484の後者はfloat aと書いてもdouble aと解釈されるのか。
流石にそこまで古いCは知らないなぁ。

488:デフォルトの名無しさん
05/10/02 20:41:06
以下の問題を配列を必ず使ってプログラミングしてください。

[課題2] 正整数を入力し、それをローマ数字で表示するプログラムを配列を使って作りなさい。
1000がM, 100がC, 10がX, 1がIであるので、たとえば、123と入力するとCXXIII、1365はMCCCXXXXXXIIIIIと出力できればよい。
<入力例>
Input: 3247

<出力結果>
MMMCCXXXXIIIIIII

お願いします。

489:デフォルトの名無しさん
05/10/02 20:56:21
初めて投稿します。
STLのiostreamヘッダを汎用テキストマッピングとして利用したいのです。
stringはtypedefで、std::basic_string<TCHAR>~としたのですがが、
iostreamはどうすればいいんでしょ?

なお、MS-Visual C++ ver 6.0で実験しています。

<ソース>
#include <tchar.h>
#include <iostream>

int _tmain(void){

// この coutとwcoutを一つにまとめたい。
std::cout << _T("Hello C++ World!\n") << std::endl;

return 0;
}

識者の皆様、ご教授お願いしたいです。

490:デフォルトの名無しさん
05/10/02 21:00:07
関数化してください。

URLリンク(briefcase.yahoo.co.jp)
問題はいってます

491:デフォルトの名無しさん
05/10/02 21:43:22
>>489
coutとかは型ではないからtypedefできない。
だからこうするしかないと思う。cinやcerr、clogも同じ。
#ifdef UNICODE
#define tcout std::wcout
#else
#define tcout std::cout
#endif

492:デフォルトの名無しさん
05/10/02 22:22:03
>>491
ご返答ありがとうございます。

なるほど、
cin, cout, cerr, clogはIOストリームオブジェクトなので、
defineで置き換えるしかないですか・・・

ご指摘を参考にしてみます。

493:デフォルトの名無しさん
05/10/02 22:57:40
>>488(前半)

#include "ctype.h"
#include "string.h"
#include "stdlib.h"
#include "stdio.h"

// 文字
static char code[4][2]={"I","X","C","M"};

int main(void){
int i, j, max, len, dec[4];
char inpbuf[5];// 4桁 + NULL
char outbuf[37];// 9文字 x 4桁 + NULL

// 初期化
memset(outbuf, 0, sizeof(outbuf));
memset(inpbuf, 0, sizeof(outbuf));

// 入力
printf("input:");
scanf("%5s", inpbuf);



494:デフォルトの名無しさん
05/10/02 22:59:11
>>488(中)
// 入力チェック
len=strlen(inpbuf);
for (i=0; i<len; i++){
if (!isdigit(inpbuf[i])){
printf("数値を入力してください\n");
return -1;
}
}
i=atoi(inpbuf);
if (i>9999 || i<0){
printf("数値は0-9999までの範囲で入力してください。\n");
return -1;
}
_itoa(i, inpbuf, 10);
len=strlen(inpbuf);

// バッファを数値に変換して
max=len-1;
for (i=max; i >= 0; i--){
dec[i]=inpbuf[i]-48;
if (dec[i]!=0)
max=len-i-1;
}



495:デフォルトの名無しさん
05/10/02 23:00:56
>>488(後半)
// 文字列作成
for (i=0; i <= max; i++){
for (j=0; j < dec[i]; j++)
strcat(outbuf, &code[max-i][0]);

}

// 出力
printf("%s\n", outbuf);

return 0;
}

くどいので、部分部分は修正してね

496:デフォルトの名無しさん
05/11/01 00:27:12
質問させてもらいます。
SDL_ttfでの表示の際にUnicode文字列が必要なのですが、
S-JISからUnicodeへの変換にはやっぱりICU使うしか無い
でしょうか?



497:デフォルトの名無しさん
05/11/01 00:27:50
質問なのでageさせて貰います。

498:デフォルトの名無しさん
05/11/01 00:55:13
いいえ

499:デフォルトの名無しさん
05/11/01 03:39:10
ぽいんた~がわかりまっせ~ん

おしえてくださ~い

500:ハーピィ
05/11/01 05:56:56
E・∇・ヨノシ <500ゲット♫

501:496
05/11/01 10:13:50
変換するのは大げさなのでデータにUTF-8で埋め込むことにしますた。

502:デフォルトの名無しさん
05/11/01 18:29:34
>>496
ちなみにマルチバイト文字(char型)にShift-JISが使われていれば、mbstowcsという標準関数が使えなくもない。

503:デフォルトの名無しさん
06/01/06 16:32:17
文字コードについてなのですが・・

a b c d eなどはASCIIコードって事はわかってるのですが
"あ"とか"い"とかは何コードなのでしょうか

strcpy(str,"あ");

printf("0x%X\n",str[0]);
printf("0x%X\n",str[1]);

とか調べてみたのですが全然判らなくて・・

504:デフォルトの名無しさん
06/01/06 16:48:32
> a b c d eなどはASCIIコードって事はわかってるのですが

ここで既に終わっている

505:デフォルトの名無しさん
06/01/06 16:52:52
ぇー数値ASCIIの数値を当てはめて出力しても期待される文字が出力されましたが

506:デフォルトの名無しさん
06/01/06 16:55:18
>>503
Windows系ならShift-JISでUnix系ならEUC-JP。ほかは知らん。
Cとしては文字コードは一定の基準さえ満たせば何でも良いということになっているから、
特定の文字コードに頼り切ったコードは書くな。

507:デフォルトの名無しさん
06/01/06 16:57:36
>>502
すみませんorz
ありがとうございました

508:デフォルトの名無しさん
06/01/08 18:59:22
演算についてなんですけど
C言語において被除数=0の時の計算っていうのはまずいですよね?

例えば
0/3
0%7
などです。

うちの処理系では例外処理が加えられて0を返すようになってるみたいなんですけど
どうでしょうか

509:デフォルトの名無しさん
06/01/08 19:44:30
んなこたーない。
もし、本当に例外処理が行なわれているとしたら、その処理系は糞未満だ。

510:デフォルトの名無しさん
06/01/08 19:58:49
>>508
0以外を返すのは数学的にもアーキテクチャから見てもおかしい。

511:デフォルトの名無しさん
06/01/08 20:00:12
0 で割る方じゃなくて、0 が割られる方なのな。

>C言語において被除数=0の時の計算っていうのはまずいですよね?
なんでまずいって思ったの?いずれも答え 0 で数学的にも正しい結果でしょ?
どっちかに負数が入る場合は C89 では処理系定義の部分は入るけど、それでも結果自体は
規定されるから例外処理なんてない。
(C99 では 0 方向に丸めるよう規定されてる)

「5.4 整数除算」を参照の事
URLリンク(seclan.dll.jp)

512:デフォルトの名無しさん
06/01/08 20:55:50
>>509-511
すいません少しこんがらがってました
0が除数である場合の計算でしたorz


513:デフォルトの名無しさん
06/01/09 21:38:36
>512
手元に C99 の規格書しかないけど、
> 9899:1999 6.5.5/5
>The result of the / operator is the quotient from the division of the first operand by the
>second; the result of the % operator is the remainder. In both operations, if the value of
>the second operand is zero, the behavior is undefined.
ということで未定義動作だから何が起こっても規格準拠だね。

514:デフォルトの名無しさん
06/01/13 09:35:53
こんにちは。質問です。お願いします。
C言語のif文で、条件式の中でfloat型の変数は使えますか?
こういう処理なんですが・・・
float fA,fB;
:
:
if(fA != fB)
{
:
}
例えば、for文の条件式とかで浮動少数型の変数を用いるのが
明らかに変なのは分かります。では、if文は、どうなのですか?

515:デフォルトの名無しさん
06/01/13 09:56:57
>>514
できるけど、やっぱり紙の上での計算と違って誤差が出るから

static float tol = 0.0001f;
float a,b;

if((a-b) < tol) {
/***/
}

とやるべきだろうね。

516:デフォルトの名無しさん
06/01/13 11:05:56
>>515
if ( abs(a-b) < tol ) {
/***/
}
なのでは?tolの値は妥当などうかも疑義がありますが

517:デフォルトの名無しさん
06/01/13 11:24:44
for(double d = 0.0; d < 100.0; d += 0.5)

誤差だけ気にしなければ別に変じゃないな

518:デフォルトの名無しさん
06/01/13 11:40:29
変だよ

519:デフォルトの名無しさん
06/01/13 15:27:00
sin(x)のマクローリン展開から√2の近似を計算するプログラムを作成したいんですが、どなたかご指導ご鞭撻の程お願いします。
sin(π/4)を2倍するところまではわかるんですが、マクローリン展開がどうもよくわからないので

520:514
06/01/13 18:21:16
早速の回答を有り難う御座います。
因みに、VC++を使っているのですが、前述の問題に関して
Debugモード、或いはReleaseの最適化を外すと
何ら問題が出ないのです・・・
コンパイラのバグなのか、誤差の問題なのか
悩むところです。。

521:デフォルトの名無しさん
06/01/13 18:41:40
自分のソースが悪い、に一票

522:デフォルトの名無しさん
06/01/13 18:55:29
>>520
浮動小数点数は同じ値でありながらビットイメージが違う場合も存在するから、
>516 の方法で丸めた方がいいよ。
tol の値は #include <float.h> して FLT_EPSILON 使えばいい。

523:デフォルトの名無しさん
06/01/13 20:30:06
見事にC言語のスレになっててワロタw

524:デフォルトの名無しさん
06/01/15 11:10:14
質問です。
#include<stdio.h>
#include<string.h>

#define N 32

void sorting(char*,char*);

main(int argc,char *argv[]){
char read[N*N],Memory[N][N],CASL[N][N][N];
sorting(CASL,read);
}
void sorting(char *CASL,char *read){
int i=0,j=0,k=0,z=0,I,J;
while(1){
I=i*(N*N);J=j*N;
if(*(read+z) == '\0') break;
else if(*(read+z) == ' '){
*(CASL+I+J+k) = '\0';
j++;k=0;
}
else if(*(read+z) == '\n'){
*(CASL+I+J+k) = '\0';
i++;j=0;k=0;
}
else{
*(CASL+I+J+k) = *(read+z);
k++;
}z++;}}
上記のプログラムでコンパイルするとwarning: passing arg 1 of `sorting' from incompatible pointer type
のエラーメッセージがでてしまいます。関数間での受け渡しで発生しているエラーだと思うのですが、どこを直せばいいのでしょうか?教えてください。

525:デフォルトの名無しさん
06/01/15 11:50:26
>>524
マルチうぜえ

526:デフォルトの名無しさん
06/01/15 11:50:43
>>524
CASL の宣言か、sorting() の引数宣言 (プロトタイプ含む)

527:デフォルトの名無しさん
06/01/15 22:23:00
floatが整数かどうかの判定ってどうします?

if(x - (int)x == 0.0f)

で良いの?
キャストに頼るのが変な気がするんですが・・・。

528:デフォルトの名無しさん
06/01/15 23:01:34
> floatが整数かどうかの判定ってどうします?

移植可能な方法で、判定する方法はない。

529:デフォルトの名無しさん
06/01/15 23:09:40
>>528
こら。modfがあるだろ。
ちなみにfloat版はmodff。

530:デフォルトの名無しさん
06/01/15 23:36:58
>>529
modf(...) == 0 とするのか?
>>527 とたいして変わらんぞ、それ。

浮動小数点に対して == 演算子を使う奴は、大抵バカ
であることがまたもや実証されたな...。

531:デフォルトの名無しさん
06/01/17 02:46:27
>527だとintの範囲を超えたときに何が起こるかわからんからmodfの方がまし。
そもそも整数かどうかの判定が必要な値にfloatを使っていることがおかしい気がするが。

532:デフォルトの名無しさん
06/01/17 09:20:37
>>531
整数というか、小数の位が存在するかどうかで処理を変更したかったので。
modfで誤差を考慮しとけば良さそうですね。

533:デフォルトの名無しさん
06/01/17 17:17:00
>>523
スレタイだけで >>1 を読まない間抜けが多いって事です。

534:デフォルトの名無しさん
06/01/24 12:41:38
配列の初期化について質問です。

int test[4] = {10, 100, 50, 1};
などの様に初期化したいのですが、
宣言した後で、このように一気に初期化する方法は無いのでしょうか?

具体的には、配列をクラスのメンバに持っていて、
コンストラクタで初期化したいのですが、
test[0] = 10;
test[1] = 100;



などのように、一つずつ初期化していくしかないのでしょうか?

535:デフォルトの名無しさん
06/01/24 12:52:00
>>534
それしかありません。

536:534
06/01/24 14:38:34
コンストラクタでローカル変数
int l_test[4] = {10, 100, 50, 1};
を作って、それをメンバの配列にmemcpyすることで解決しました。

あまりキレイな解決策ではないですが、
実際は2次元配列で要素が多かったので、どうしても一気に初期化したかったのでした。

537:デフォルトの名無しさん
06/01/24 22:06:31
> コンストラクタでローカル変数
> int l_test[4] = {10, 100, 50, 1};
> を作って、

まあ、最近のマシンなら気にすることではないのだろうが、
static const をつけておいた方がちと早くなるかもし
れない。

538:デフォルトの名無しさん
06/01/25 06:19:38
何故vectorかなにかのコンテナを使わないのだろう。

539:デフォルトの名無しさん
06/01/25 07:40:22
>538
それはさすがにスレ違い。

540:デフォルトの名無しさん
06/01/25 17:51:24
このスレで「スレ違い」って言われてもな

541:デフォルトの名無しさん
06/01/27 16:02:03
スレタイに半角の#を入れようとしたのが問題

542:デフォルトの名無しさん
06/01/27 22:59:12
>>541
これってCすれじゃなかったのか!!!!

543:デフォルトの名無しさん
06/01/27 23:08:23
気付いてない子がいたのか・・・

544:デフォルトの名無しさん
06/02/02 23:17:53
for(;;);
for(;;)
といった文を見たんですがこういう文はどういう働きをするんでしょうか?

545:デフォルトの名無しさん
06/02/02 23:27:06
ループ・ザ・インフィニット! ・・・とかって言うとスタンドっぽくね?

546:デフォルトの名無しさん
06/02/02 23:41:02
>>544
forの括弧の中の3つのそれぞれの部分は省略できる。
2つのセミコロンの間の継続条件を省略すると無限ループになる。

547:デフォルトの名無しさん
06/02/03 16:06:33
>>546
すいません、ちょっと言葉足らずでした。

for(初期条件;終了条件;加算);
for(初期条件;終了条件;加算){
文;
}

こんな感じの文だったのですが、
最初のfor文の最後に ; が入った形をみたことがなかったので、
この2個のfor文がどのように動くのかを教えてほしいです。

548:デフォルトの名無しさん
06/02/03 16:16:08
rr

549:デフォルトの名無しさん
06/02/03 16:21:58
>>547
↓こう書いたら解る?
for(初期条件;終了条件;加算)
  ;

550:デフォルトの名無しさん
06/02/03 16:23:07
>>549
何もしないんですね。orz
理解できました。ありがとうございます。

551:デフォルトの名無しさん
06/02/03 21:35:03
#include <stdio.h>
int main(){
int *pa[500],*pb[500],*pc[500],*pd[500],*pe[500],*pf[500];
int i;
for(i-0;i<500;i++){
*pa[i]=5;
*pb[i]=5;
*pc[i]=5;
*pd[i]=5;
*pe[i]=5;
*pf[i]=5;
printf("%d,%d,%d,%d,%d,%d\n",*pa[i],*pb[i],*pc[i],*pd[i],*pe[i],*pf[i]);
}
return 0;
}
このプログラムってかなりやばいよな;

552:デフォルトの名無しさん
06/02/03 21:35:49
>>551
マルチうざい

553:デフォルトの名無しさん
06/02/04 16:45:57
構造体についての質問です。

#include<stdio.h>
struct string{
char *a;};
struct string data[]={
"a","b","c","d",};

int main(){
struct string *p;
char *s;
int i;
scanf("%s",&s);
p=data;
for(i=0;i<=3;i++){
if(s==(p+i)->a){
printf("%s\n",(p+i)->a);}}
return 0;
}
以上をコンパイルして実行した場合、scanfで入力した値がa~dのどれかでも
if(s==(p+i)->a)が真と判断されないのですが、間違いについての教唆をお願いします。

554:デフォルトの名無しさん
06/02/04 16:57:35
>>553
>間違いについての教唆をお願いします。

教え唆すのか?


555:デフォルトの名無しさん
06/02/04 17:13:29
そそのかされてどうする俺…
普通に間違いについて教えてほしいです

556:デフォルトの名無しさん
06/02/04 17:23:21
たとえば、scanf で "abc" という文字列を読み込んで、
それらの文字一つ一つ( 'a' とか 'b' とか 'c' とか '\0' とか・・・)は
メモリの何処に保管されるのさ?

今、値を記憶できる変数の領域は string 構造体のアドレスを保持する p と
char のアドレスを保持する s と
int の値を保持する i しかないぞ?


557:582
06/02/04 18:00:29
>>553
よーし、パパそそのかしちゃうぞ。

よくコンパイル通ったな。 構造体のメンバが char へのポインタ1つだけと判っていれば、
構造体配列 = { char*その1, char*その2, ・・・ , char*そのn }
なんて初期化が許されるのか ・・・ 知らなかった (マジ
ここは、
struct string data[]={
{"a"}, {"b"}, {"c"}, {"d"}
};
じゃなきゃ い神埼だと オモテタ。

でも、バグの本質は、>>556 の指摘のとおり。
scanf() で、ポインタ変数にコンソール入力しようとしているが、おまえには特定の
char の場所を示すポインタ ( アドレス ) が判るのか? メモリの中身に詳しいヤツ
だな。

558:デフォルトの名無しさん
06/02/04 18:23:12
本当に唆しているだけだなお前ら。

559:553
06/02/04 19:25:32
>>556-557
charで*でなく適当な長さの配列を宣言して
if()で照会するのは2つの配列[0]に格納した値…ってことですね。
どうみても俺の勉強不足です。本当にありがとうございました

560:デフォルトの名無しさん
06/02/13 03:43:09
関数を定義するときに
void xxx(int yyy)
int A;
char B;
{
~~~
}
こんなふうに書かれたものを良く見かけるのですが
このときAとBは何か特別なものなんですか?

561:デフォルトの名無しさん
06/02/13 08:39:53
>>560
void xxx(int yyy)
{
...;
}
ならば、古いスタイルで
void xxx(yyy)
int yyy;
{
...;
}
となるがそのことだろうか。
それならばプロトタイプ宣言のなかった時代の名残だ。

562:デフォルトの名無しさん
06/02/27 10:34:29
Borland C Compilerのエラーメッセージについて詳しく解説している
『bcc32_messages』というファイルがあるのですが(中には数百のHTMLが
入っていて、エラーと警告1つ1つに細かい説明が書かれている)、どなたか
これの英語版がどこにあるかご存じないでしょうか?

563:デフォルトの名無しさん
06/04/21 23:47:15
COMMAND getCommand(char *c)
{
       int i, j, k, l, len;
       char comtmp[128], fileNametmp[128], comExtmp[128];
       COMMAND command;

       len = strlen(c);
       for(i=0; i<len+1; i++){
             if(c[i] == '-'){
                     for(j=0; c[i]!='\0'; j++){
                            i++;
                            if(c[i] == '@'){
                                   comtmp[j] = '\0';
                                   for(k=0; c[i]!='\0'; k++){
                                          i++;
/*printf("\nc[%d] = %c\n", i, c[i]);*/
                                          if(c[i] == '>'){
/*printf("\n>>in\n");*/
                                                 for(l=0; c[i]!='\0'; l++){
                                                        i++;
                                                        comExtmp[l] = c[i];
printf("\nc[%d] = %c\n", i, c[i]);
                                                 }
                                          }

564:デフォルトの名無しさん
06/04/21 23:48:36
                                          if(c[i] == '\0'){
                                                 comExtmp[k] = '\0';
                                                 command.com = malloc(sizeof(char)*(strlen(comtmp)+1));
                                                 command.fileName = malloc(sizeof(char)*(strlen(fileNametmp)+1));
                                                 command.comEx = malloc(sizeof(char)*(strlen(comExtmp)+1));
                                                 strcpy(command.com, comtmp);
                                                 strcpy(command.fileName, fileNametmp);
                                                 strcpy(command.comEx, comExtmp);

                                                 return command;
                                          }
                                          fileNametmp[k] = c[i];
                                   }
                            }else if(c[i]!='\0'){
                                   comtmp[j] = c[i];
                            }
                     }
              }else if(c[i]=='\0'){
                     break;
              }


565:デフォルトの名無しさん
06/04/21 23:52:41
       }

       command.com = NULL;
       command.fileName = NULL;
       command.comEx = NULL;

       return command;
}

質問です。
このプログラム、-xxxxxx@yyyyyy>zzzzzz  (x, y, z は不定)
という文字列から command.com = xxxxxx
            command.fileName = yyyyyy
            command.comEx = zzzzzzz
に文字列を分けて入れるプログラムです。
printfが変なところに3つあるのはデバッグのためなのですが、上から3つ目のprintfをコメントアウトするとバグが起こり、
コメントアウトしないでprintf出力するとバグが起こりません。なぜでしょうか?

-insert@123.bmp>rgb と入力した時、fileNameにstrlen()で文字列数を調べたところ、
3番目のprintf()をコメントアウトしなかった場合、7文字と正確に入っていて。
コメントアウトした場合、11文字とでます。
コンパイラーはbccの5.5で、windowsXPを使用しています。

Σ( ゜д゜)うわ
プログラム超見づらい。
すみません;;

566:542
06/04/22 00:08:46
ほら、皆間違えるw


567:デフォルトの名無しさん
06/04/22 18:37:12
実行ファイル(***.exe)の作成の仕方がわからないのですが…。

568:デフォルトの名無しさん
06/04/23 15:38:33
>567
一行目に
#!/bin/sh
って書いて
chmod +x
してから、ファイル名に.exeをつけるだけだよ。


569:デフォルトの名無しさん
06/04/27 21:47:48
今日はじめてc言語のテキストを買いました。
初心者です。
コンパイル時?に
インクルードファイル ’stdio.h’をおーぷんできない
とエラーメッセージが出てきました

テキスト読んでもわかりません
解決方法があれば教えてください

570:デフォルトの名無しさん
06/04/27 22:20:47
>>569
きちんとインストールしたか?
特にBorland C++ならbcc32.cfgなど。

571:デフォルトの名無しさん
06/04/27 22:41:25
>>570
どもです
cfgファイルを作ったんですが
コンフィグレーションファイル中の オプションの間違い と
難しいですね

572:デフォルトの名無しさん
06/04/28 07:22:00
コンパイルするとstudio.hが見つからないと出るのですが、バグですか?


573:デフォルトの名無しさん
06/04/28 07:29:26
stdio.hだよ。studioじゃない。

574:デフォルトの名無しさん
06/04/28 11:15:51
stdioがスタンダードI/Oだって知らないのかな

575:デフォルトの名無しさん
06/04/28 17:05:46
Cmachineと言うフリーソフト持っている方いませんか?
公開終了してたので・・・orz
持ってる方うpお願いします…

576:デフォルトの名無しさん
06/04/28 17:08:37
>>575
C のスレと間違うならまだしも、まるっきりスレ違い。
阿呆は帰れ。

577:575
06/04/28 17:19:26
>>576
書き忘れましたが、C言語のソフトです・・・
あほですいません・・・orz

578:デフォルトの名無しさん
06/04/28 21:19:52
初心者で本当にすみません
scanf関数を使っていたときに、パラメータに"&"を付け忘れました
俺のPCはあぼーんですか?

579:デフォルトの名無しさん
06/04/28 21:30:13
>>578
心配なら再起動しろ。

580:578
06/04/28 23:13:51
>>579
ありがとうございます。
さっき電源落としたんで、後で立ち上げてみます。
授業でscanf習った時に先生に死ぬほど脅されてたんで正直ガクブルです

581:デフォルトの名無しさん
06/04/29 00:34:50
ワロタ

582:デフォルトの名無しさん
06/04/29 01:04:58
-|"c:\Borland\Bcc55\include"
-L"c:\Borland\Bcc55\lib"
bcc32.cfg

コンフィグレーションファイル中の オプション間違い:-|"c:\Borland\Bcc55\include"
というエラーが出てしまいます

どうすればいいでしょうか?
教えてください。

583:デフォルトの名無しさん
06/04/29 02:22:18
|とIが区別出来るフォントを使えばいいと思うよ

584:デフォルトの名無しさん
06/04/29 12:16:12
>>583
ホントですか?
半角入力にですか。

テキストでは |とl の区別がなく書いてあるのでわかりずらいです。


585:デフォルトの名無しさん
06/04/29 12:28:03
>>583
ありがとうございました
|とiの違いですね。

586:デフォルトの名無しさん
06/04/29 15:13:16
warota

587:デフォルトの名無しさん
06/05/02 11:27:23
>>580
死ぬほど脅すくらいなら、最初っから教えなきゃいいのになぁ。

588:デフォルトの名無しさん
06/05/08 13:47:17
LSI C-86 Ver.3.30 試食版のことでお尋ねします、OSはWindows2000です
エスケープシーケンスを使いたいと思ってなんとか使えるようにはなりました。
しかし、カーソルを全角用の2文字分の長い方に変えるのはどうやってやったらいいでしょうか


589:デフォルトの名無しさん
06/05/08 15:34:00
↑同じ質問を違うスレでしていますが、いろいろ試行錯誤した結果での話です
決してマルチをしようとしたつもりはございません
何なら無視して頂いてもかまいません

590:デフォルトの名無しさん
06/05/08 16:20:17
それ以前にスレ違いだ。
>>1を読んでいないことがバレバレだぞ。

591:デフォルトの名無しさん
06/05/08 16:23:18
>>1よりもスレタイが重要だと思う。

592:デフォルトの名無しさん
06/05/08 17:36:16
だから間違えたって言ってるだろ

593:デフォルトの名無しさん
06/05/08 20:57:59
URLリンク(cgi.2chan.net)

このコードをCygwinでコンパイルした結果
$ gcc -o client client.c
client.c: In function `main':
client.c:14: error: storage size of `server_adrs' isn't known

とエラー吐かれたのですが、修正方法が分かりません
修正方法教えていただけませんか?

594:593
06/05/08 22:09:10
すいません、ソースURL間違えてました
URLリンク(namihei.zone.ne.jp)
です、お願いします

595:デフォルトの名無しさん
06/05/09 11:45:14
>>593
だから激しくスレ違いなんだってばさ。
書き込む前に>1を読むとか直前の数レスを眺めるってこともできないのか?
cygwinスレかネットワークスレ辺りで聞いて味噌。

596:デフォルトの名無しさん
06/05/09 20:49:10
スペースで区切られた文字列を分割する関数を作ります。

・連続するスペースはひとつの区切りとしない
・スペースがない場合は全ての文字列を返す
・頭や後ろにつくスペースは無視
・返す文字列がない場合はNULLを返す
・初期値の文字列はNULLを引数に与えている間に変更されないもとする
・#include<string.h>は使わない

ですが、さっぱりわかりません。
どうか教えてください。

597:596
06/05/09 20:57:45
引数は( char * , const char * )です。
第1引数は区切られた文字列の格納先
第2引数はスペースで区切られた文字列(次の文字列を探す時はNULLを指定)
です。

598:デフォルトの名無しさん
06/05/09 20:59:26
宿題なら宿題のスレッドへ行くが吉。

599:デフォルトの名無しさん
06/05/10 00:11:15
#include <stdio.h>
main(){
float x=0.0;
double xx=0.0;
long i,n=100000;
for(i=1;i<=n;i++){
x=x+1/(float)(i*i);
xx=xx+1/(double)(i*i);
}
printf("from 1/1^2 to 1/%d^2, x(dbl)=%f, x(flt)=%lf\n",n,xx,x);

x=0.0;
xx=0,0;
for(i=n;i>=1;i--){
x=x+1/(float)(i*i);
xx=xx+1/(double)(i*i);
}
printf("from 1/%d^2 to 1/1^2, x(dbl)=%f, x(flt)=%lf\n",n,xx,x);
}
1/1^2+1/2^2+・・・+1/100000^2を計算するプログラムを作成せよという問題で、1/1から加えたときと1/100000から加えたときとそれぞれフロートとダブル型の4パーターン
比較する課題なんですが、実行するとバグってしまします。このプログラムのどこおかしいですか?コンパイラはborlandgccです





600:デフォルトの名無しさん
06/05/10 00:16:41
>>599
まずおかしいのはスレッドの選び方。ここはC♯のスレッドです。
次におかしいのは日本語。パーターンってなんです?
またおかしいのはコミュニケーション能力。バグってしまうだけでは何も通じません。
更におかしいのはコンパイラ。borlandなのかgccなのかはっきりなさい。


601:デフォルトの名無しさん
06/05/10 00:18:13
>>600
すげー眠いのでもうだめです。今日はねます。すいませんでした

602:デフォルトの名無しさん
06/05/10 00:18:31
>>599
>>595は見えてますか?

603:デフォルトの名無しさん
06/05/10 00:23:46
ここをC言語のスレとして扱っちゃ駄目なのか?
>>599
iが65536以上の時、i*iは32ビットでは表現できないので、オーバーフローしているんだろう。
(double)(i*i)の代わりに(double)i*iとすればいい。

604:デフォルトの名無しさん
06/05/10 00:31:29
>>603
動作するようになりましたが、結果がおかしくなりました


605:デフォルトの名無しさん
06/05/10 00:54:51
>>604
ごめん、括弧が要る。
((double)i*i)

606:デフォルトの名無しさん
06/05/10 00:57:38
>>603
>ここをC言語のスレとして扱っちゃ駄目なのか?
じゃ、重複スレなわけね。

607:デフォルトの名無しさん
06/05/10 01:01:02
そういうことになるな。

608:デフォルトの名無しさん
06/05/10 13:23:27
じゃ削除だね

609:デフォルトの名無しさん
06/05/10 15:33:33
そういえば3月・4月のスレ削除依頼がまだ処理されてないな。

610:デフォルトの名無しさん
06/06/03 01:37:14
f (x) = cos (x) - x2 = 0 の根のうち、0 < x < 1 を満たすものを2分法で求める  
初期値 a, b が入力でき、 6桁推定された解と関数 f (x) を呼びだした回数を出力する方法を教えてください。  


611:デフォルトの名無しさん
06/06/03 11:03:53
>>610
細かな調整は勝手にやれ
#include <iostream>
using namespace std;

double f(double x){
double fx;
fx = cos(x) - x*x ;
return fx ;
}

double bisection(double a, double b,double (*)(double),int prc);
int main(){
double a,b;
double k;
cout << " a : " ;
cin >> a ;
cout << " b : " ;
cin >> b ;
k = bisection(a,b, f,100);
cout<<"cos(x) - x^2 := " << f(k) << " at " << k << endl;
return 0;
}
(2分法は次)

612:デフォルトの名無しさん
06/06/03 11:04:35
続き

double bisection(double a, double b, double (*func)(double ),int prc){
if (func(a)*func(b) >= 0) return a; //意味ないし a で十分w
double up, lo , m;
if( func(a) > func(b) ){ up = a; lo = b ;}
else { up = b ; lo = a; }

double workprod;
int workint ;
int counter=0;

while(1){
m= (up + lo)/2;
workprod = func(m);
workint = ((int)(workprod * 1000000)); // /100.0;
if(workint==0){
cout << "counter value = "<< counter <<endl;
return m;
}
if(workint > 0) up=m;
if(workint < 0) lo=m;
counter++;
if (counter > 20000) break;
}
return 0.0;
}



613:デフォルトの名無しさん
06/06/03 19:55:14
>>611-612
1.宿題に答えるのはスレ違い
2.>>1も読めないカスは失せろ

614:デフォルトの名無しさん
06/06/03 23:02:06
>>613
1?
笑わせるなヨ
ここは元々利用価値のないクズスレ
悔しかったら削除依頼出して来いヤw

612も読めねえクズが

615:デフォルトの名無しさん
06/06/03 23:14:16
カススレ晒しage

616:デフォルトの名無しさん
06/06/03 23:20:45
すいません、初心者なのですがdupという関数について教えてください。
openしたファイルポインタAをdupで複製?した場合というのはAをclose
すれば複製したファイルポインタもcloseされるのでしょうか?
dupの認識が違っていたらすいません

617:デフォルトの名無しさん
06/06/04 01:27:25
単利計算と複利計算を行うプログラムについて、質問させてください。
環境はWindowsXP.VS.NET2003。Win32コンソールアプリケーションです。
void main()
{
float a,r,c;/*r:金利c:複利*/
int i,y,method; /*預ける年数*/
printf("いくら預けますか?");
scanf("%lf",&a);
printf("何年間預けますか?");
scanf("%d",&y);
printf("運用方法を設定してください。単利なら0,複利なら1を入力してください。");
scanf("%d",&method);
if(method==0){
printf("金利はいくら(%%)ですか?");
scanf("%f",&r);
for(i=1;i<=y;i++){
a +=a*(r/100);
}
printf("元本は%f円になります\n",a);
}
else if(method==1){
printf("複利はいくら(%%)ですか?");
scanf("%f",&c);
for(i=1;i<=y;i++){
a = a*(1+r/100);
}
printf("元本は%f円になります\n",a);
}
else printf("終了します。\n");
}
ですが、いざ元本を出そうとすると、Stack around the variable 'a' was corrupted.
と表示されてしまいます。お力添えの程出来たらよろしくお願いいたします。

618:デフォルトの名無しさん
06/06/04 10:03:00
>>617
> scanf("%lf",&a);
scanf系において%lfはdobuleを意味する。

floatを使う必要なんてない。全部doubleでいい。
そもそもお金が絡むのに浮動小数点数を使ってよいのかという問題もあるが。
void main()を使う必要もない。int main()でいい。

619:デフォルトの名無しさん
06/06/04 21:18:38
>>618
ありがとうございました。
単利の計算が間違っていた(複利と一緒だったorz)。
ので直しましたが、それ以外はうまくいきました。

小数点以下は二桁まで取ることにしました。
ありがとうございました。

620:デフォルトの名無しさん
06/06/29 09:02:45
scanf("%d",&r);
scanf("%d",&h);
A=ff (r,h);
ff=f2;
V=ff (r,h);
printf ("表面積=%f 体積=%f",A,V);
return 0;
}(後は省略)

この問題でhとrをよみこみたいんですけど
こういうふうに書くとどんな数字を読み込んでも答えが0になって
しまうんですけどどこが間違ってますかね・
ちなみにscanfのかわりにh=1とかって定義すればしっかり値はでます。

621:デフォルトの名無しさん
06/06/29 09:03:58
すいません途中しかコピペしてませんでした。こんな感じです
#include <stdio.h>
#define PAI 3.14159
double a,b,r,h,A,V;
double f1 (double r2,double h2);
double f2 (double r2,double h2);
main(void)
{

double (*ff)(double r2,double h2);


ff=f1;
scanf("%d",&r);
scanf("%d",&h);
A=ff (r,h);
ff=f2;
V=ff (r,h);
printf ("表面積=%f 体積=%f",A,V);
return 0;
}


622:デフォルトの名無しさん
06/06/29 09:14:35
うはぁ、突込みどころが満載だ。
・doubleで計算したいならPAIは精度が足りない。
・そもそもPAIってなんだよw
・変数は極力グローバルに置かない方がいい。
・f1()とf2()が外部にあるなら、宣言はインクルードファイルで行なう方がいい。
・関数名は特別な理由でもない限り、中身が判る名前にしよう。
・main()の戻り値型は書くべき。
・実験的にやってみたいだけなら止めないが、関数ポインタを使う必然性がない。
・scanf()で型指定子を%dにするならint *を渡す必要がある。
・逆に、double *を渡したいなら型指定子は%lfだ。
・そもそもここはC♯の立て損なったネタスレだ。

623:デフォルトの名無しさん
06/06/29 09:19:13
ほんと、ごめんなさい
でも解決しました><

624:デフォルトの名無しさん
06/07/02 00:23:44
愚かな俺に教えて下さいまし、みなさま・・・

BYTE byData = 0x0f;
byData = byData << 4;
  (VC .net SP 適用なし)

これ実行すると byData が 0 になる。
3 ビットシフトだとちゃんと 0x78 になるのに・・・。

なぜだぁぁぁぁぁ!!

625:デフォルトの名無しさん
06/07/02 00:47:36
>>624
自己解決

VC .net のシンボルウォッチのバグですた・・・
おぃおぃ、VC6 から劣化してどーすんのよ MSさん~~orz

626:デフォルトの名無しさん
06/07/19 05:49:05
2つ整数を入力して商と剰余を求めるんですが・・・
20-6=14 14-6=8 8-6=2 3回引いたので商が3、剰余は2、というふうに求めろ、という問題です。
商は4、剰余4と出てしまいます。
#include <stdio.h>
void main(void)
{
int a,b,c,d,e,f;
printf("2個の正の整数を入力\n");
scanf("%d %d",&a,&b);
if (b>=a)
{
c=b;
b=a;
a=c;
}

d=a-b;
e=1;
while (d>=0)
{
d=d-b;
e=e+1;
}
printf("商%d 剰余%d",e,d);
}

627:デフォルトの名無しさん
06/07/19 07:17:44
d>=0だったら一回余分に計算しちまいますね・・・
自己解決しました。スレ汚しすんません。

628:デフォルトの名無しさん
06/08/15 08:13:19
巨大な乱数ファイルの後ろから1文字ずつ消していき、
ファイルサイズを2GByteにすることってできますか?
ファイルサイズを取得するまではいけたのですが、
1文字ずつ消す方法がわかりません。
消す方法はありませんか?

629:デフォルトの名無しさん
06/08/15 11:09:04
>>628
一文字ずつじゃなきゃいけないの?
ファイルサイズを単純に切り詰めるだけでいいならbsd/POSIX系関数で
truncate()/ftruncate()なんてのがあるけど。

630:デフォルトの名無しさん
06/08/15 11:14:03
#include <stdio.h>
void mystrcpy(char *strA, char *strB);

int main(void)
{
char str1[11], str2[11];

puts("Input str1[11]");
fgets(str1, 10, stdin);

mystrcpy(str1, str2);
printf("str1 = %s\n", str1);
printf("str2 = %s\n", str2);

return 0;
}
void mystrcpy(char *strA, char *strB)
{
int i;
for(i=0; *(strA+i); i++){
*(strB+i) = *(strA+i);
}
}
strcpy関数を自分なりにつくっていたところ、上のようなものができました。
ですがコンパイルして実行すると文字列のコピーはうまくいっているものの、
変な文字列(文字化けした文字)も出力されてしまいます。
どこらへんがおかしいのでしょうか?
(環境はWinXPHome、コンパイラがBorland C++ 5.1.1です)

また、先週からC言語を勉強し始めたのですが、
ポインタを引数にしたり戻り値として利用するところが自分には少々難しいと感じています。
何かわかりやすい本やウェブサイトがあったら紹介していただけないでしょうか。

631:デフォルトの名無しさん
06/08/15 11:19:39
>>630
文字列の終端の'\0'をコピーしていない。

632:630
06/08/15 11:31:59
おお、まさにその通りです。
助かりました。

while(*(strB++) = *(strA++));

として解決しました。

633:デフォルトの名無しさん
06/08/15 13:35:40
>>629
一文字ずつじゃなくてもいいのですが、
ケツから2MByteくらいを消したいんです。
学校の課題なんで、切り詰めるだけでもばれないとは思いますが・・・。

#もし乱数データじゃなかったらばれるか。
#でもメモリ足りなくて開けないし・・・。

634:デフォルトの名無しさん
06/10/08 11:48:34
ここってC#スレ?

635:デフォルトの名無しさん
06/10/15 08:22:41
CとC#を一緒にすんなヴォケ

636:タイトルのシャープが剥がされることも知らないのだろうか
06/10/15 10:39:11
>>635
>1

637:デフォルトの名無しさん
06/10/15 10:46:47
立てた奴の意図などどうでも良い。

638:デフォルトの名無しさん
06/10/16 14:28:51
>>633
き ゃ ぴりん ☆ き っく ! でググれ

639:デフォルトの名無しさん
06/11/10 13:56:33
質問です。
const int getHoge(){ return m_nData;}

というように、返り値にconstをつける意味はなにかあるのでしょうか?
ポインタなどを渡している場合ならわかるのですが、intやshortの場合の必要性がわかりません。


640:デフォルトの名無しさん
06/11/10 16:38:07
>>639
製作者がconstなんだと叫びたいとき。
というのは冗談だが、Cではともかく、C++では違いが全然ないわけではない。
int foo();
const int bar();

template<typename T>
void hoge(T& x);

void f()
{
    hoge(foo()); //エラー:xはint&になるが、非constな参照型のインスタンスは右辺値で初期化できない。
    hoge(bar()); //xはconst int&になり、constな参照型のインスタンスは右辺値で初期化できるのでエラーにならない。
}
まあ普通はこんなことを気にする必要はない。

641:デフォルトの名無しさん
06/11/10 17:04:47
>>640
ありがとうございます。
微妙な違いですね。

別のことを試してみたところ、const int getHogeは、
int n = getHoge()
とできてしまいました。全然constじゃないじゃん!
「エラー値とかだから計算する必要ないでしょ!だからconst!」って使い方をしようかと思ったのですが…。

素直にエラーはenumで型つけてやるほうがよさそうです。
ありがとうございました。



次ページ
最新レス表示
レスジャンプ
類似スレ一覧
スレッドの検索
話題のニュース
おまかせリスト
オプション
しおりを挟む
スレッドに書込
スレッドの一覧
暇つぶし2ch