C統合・質問スレッド ..
[2ch|▼Menu]
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;
              }



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

5373日前に更新/239 KB
担当:undef