スレを勃てるまでもな ..
[2ch|▼Menu]
178:デフォルトの名無しさん
09/05/20 12:08:56
>>177
だから、単に自分の権威を見せつけたいというのと対抗意識の現れでしかないんだよ。

179:デフォルトの名無しさん
09/05/20 12:12:13
団塊世代は技術もなければ精神性も低い。
社会のゴミですね。

180:デフォルトの名無しさん
09/05/20 12:14:42
>>178
うん、そうかもね。
だから?w
それで出世あきらめるの?

181:デフォルトの名無しさん
09/05/20 12:17:26
>>180
技術盗んだら海外におさらばするつもり

182:デフォルトの名無しさん
09/05/20 12:18:53
もう俺が悪いって事でいいからけんかはよせ

183:デフォルトの名無しさん
09/05/20 12:26:22
あーあ 団塊世代のせいでまた人材が日本から流出していく。
さすが社会のゴミ 国賊 団塊世代は日本をつぶす気か

184:デフォルトの名無しさん
09/05/20 12:30:53
何でも他人のせいにするところはどっかの民族とそっくりだな。

185:デフォルトの名無しさん
09/05/20 12:40:46
>>183
団塊世代が悪いかどうかは知りませんが、うちの会社でも団塊世代の天下りを受け入れない方針になったみたいですよ。
まぁ、最近の世論的に天下りはまずいからでしょうが。

186:デフォルトの名無しさん
09/05/20 16:43:34
Windows上でLinuxを起動させたいのですが
VMwareソフトウェアのどのシリーズを選んだらいいのでしょうか?

187:デフォルトの名無しさん
09/05/20 16:44:38
vmware serverをダウンロードしてインストールしる

188:デフォルトの名無しさん
09/05/20 17:14:03
ようしゃなく英語やったorz

189:デフォルトの名無しさん
09/05/20 17:18:15
日本人のくせに英語もできないのか

190:デフォルトの名無しさん
09/05/20 18:17:16
敵性言語として長く使用を禁じられていたので…

191:デフォルトの名無しさん
09/05/20 19:13:14
じゃぁ なでしこでWMwareと同レベルのものを作ってください

192:デフォルトの名無しさん
09/05/20 19:15:49
今は属国なんだからしっかりしる!

193:デフォルトの名無しさん
09/05/20 22:47:50
#include <iostream>
using namespace std;
int main(){
int tmppl;
cin>>tmppl;
int const pl=tmppl;
int php[pl];
return 0;
}

あらかじめ数字を入力して変数tmpplに入れておき
const plの初期化の際にtmpplを使おうと思ったのですがコンパイルエラーが出ます
これは無理なんでしょうか?

また配列の要素数をキーボードで入力した数字で決めたいのですが、どうすればよいでしょうか?

194:デフォルトの名無しさん
09/05/20 22:54:38
>あらかじめ数字を入力して変数tmpplに入れておき
>const plの初期化の際にtmpplを使おうと思ったのですがコンパイルエラーが出ます
>これは無理なんでしょうか?

無理です

>また配列の要素数をキーボードで入力した数字で決めたいのですが、どうすればよいでしょうか?

std::vector

195:デフォルトの名無しさん
09/05/20 22:58:06
int *php=new int [pl];

196:デフォルトの名無しさん
09/05/20 23:07:30
>>194>>195
ありがとうございます!
初期化と代入の違いが何となく分かりました

197:デフォルトの名無しさん
09/05/21 00:31:36
それは初期化とか代入の話じゃなくて
配列の添え字はコンパイル時定数でなければならないという仕様の話じゃないのかい?
っていうか、前にもまったく同じ回答をした気配がする。

198:デフォルトの名無しさん
09/05/21 03:35:38
extern就職誌というのを知らなかったので試してみたら疑問がでました。
(main.cpp)
#include <iostream>
int global = 100;
extern void func(); //ココをexternとっても動作する
int main() {
std::cout << ::global << std::endl;
::func();
return 0;
}

(another.cpp)
#include <iostream>
extern int global;
void func() {
std::cout << ::global << std::endl;
}

俺の理解している範囲ではexternをつけると「この変数もしくは関数はグローバルだ。ただし定義自体はこのファイルでなくて
別のソースファイルでしているから気をつけろ。」ということなのだが、上記のソースではどうも動作が違う。
最初にメイン関数内でグローバル変数のglobalを表示するのはいいだろう。
次にグローバル関数のfuncに突入するのだがfuncはexternがついているので別ファイル、すなわち
another.cppで定義されている。それで実行は可能なのだが試しにメインのextern void func()からexternをとってみた。それでも
動作したのだが、なんで動くんだ?

199:デフォルトの名無しさん
09/05/21 03:57:19
>>extern就職誌

素晴らしい

200:デフォルトの名無しさん
09/05/21 03:59:50
で、とりあえず、externは、「この名前がグローバルだ」とするためのもの。
そのコンパイル単位で定義されているかどうかは関係ない。

それと、関数はデフォルトでextern。
つまり、staticを付けないで宣言(定義も)されたものは、全てexternと同等となる。

201:デフォルトの名無しさん
09/05/21 04:00:00
海外転職誌みたいだな。

202:デフォルトの名無しさん
09/05/21 04:00:17
本題に答えろ

203:デフォルトの名無しさん
09/05/21 04:07:44
URLリンク(eow.alc.co.jp)

通勤医師の就職誌か。

204:デフォルトの名無しさん
09/05/21 04:12:30
おまえ、辞書引いたのか。。

205:デフォルトの名無しさん
09/05/21 08:10:30
>>200
んー、よくわからんのですがとりあえず関数はおいておいて変数については
「この変数はグローバルだ。ただし定義自体はこのファイルでなくて 別のソースファイルでしているから気をつけろ。」
この定義は間違っていますか?それとも合っている?今、同じソースファイルで宣言だけでなく定義もしたらエラーに
なったのですが。。わかりやすい説明モトム
(main.cpp)
#include <iostream>
extern int global;
int global = 4;
void func();
int main() {
std::cout << ::global << std::endl;
::func();
return 0;
}

(another.cpp)
#include <iostream>
void func() {
std::cout << ::global << std::endl;
}


206:デフォルトの名無しさん
09/05/21 08:20:02
どんなエラーだよ
まさか宣言しないシンボルを使おうとかしてないよな

207:デフォルトの名無しさん
09/05/21 08:24:49
another.cppの中ではglobalが何者かわからん。

208:デフォルトの名無しさん
09/05/21 08:45:54
動けばいいんだよ。動けば。

209:デフォルトの名無しさん
09/05/21 11:26:55
コンパイルできない なんでか教えて

#include <iostream>
class Point {
private:
int m_x;
int m_y;
public:
Point(int x = 0, int y = 0): m_x(x), m_y(y) {}
void show() {
std::cout << "m_x = " << m_x;
std::cout << ", m_y = " << m_y << std::endl;
}
Point *operator+(Point *p) {
m_x = m_x + p->m_x;
m_y = m_y + p->m_y;
return *this;
}
};

int main() {
Point *p1 = new Point(3, 4);
Point *p2 = new Point(5, 8);
p1->show();
p2->show();
Point *p3;
p3 = p1 + p2;
p3->show();
return 0;
}

210:デフォルトの名無しさん
09/05/21 11:50:47
>>209
Point *operator+(Point *p) {
...
return this;
}

p3 = *p1 + p2;

コンパイルするだけならこう変更する

211:デフォルトの名無しさん
09/05/21 11:53:23
ありがとうございます
仮にp3 = p1 + p2;
を計算させたい場合は関数定義はどうすればいいですか?

212:デフォルトの名無しさん
09/05/21 13:01:54
ポインタ演算をオーバーロードするのはオススメできない
どうしてもやりたいなら「フレンド関数 オーバーロード」あたりでぐぐれ

あと補足だけど>>210はp1==p3になるから気を付けてね

213:デフォルトの名無しさん
09/05/21 15:22:46
了解しました。

214:デフォルトの名無しさん
09/05/21 16:32:56
std::cout << "ABCDEFGHIJKLMN";
std::cout << "\r12345\n";

とすると12345ABCDEFGHIJKLMNと表示される。
\rは復帰、現表示位置がその行の先頭に移動する。

というのはわかるが、一体何の役に立つんだこれ?
マジで使ったことある人いたら教えてくれ

215:デフォルトの名無しさん
09/05/21 16:40:09
歴史的遺物

216:214
09/05/21 16:41:05
興味程度にどんな歴史的遺物か教えてくれ

217:デフォルトの名無しさん
09/05/21 16:42:37
コマンドライン上で簡易進捗バー出すのに便利。

218:デフォルトの名無しさん
09/05/21 16:49:36
>>205
externは、別のファイルで定義しているリソース(変数とか)を
このファイルでも流用するよ、っていう宣言。
C++では、変数名・関数名などは、その変数・関数を使用するより前に、
それが何なのかを同じファイル中でコンパイラに教えてやらないとエラーになる。

お前さんのソースの中で、グローバル的に使用されているのは、
void func()とint globalの2つ。
func()を使用しているのはmain.cppだが、ここではfunc()を使用するより
前に
void func();
と宣言してあるから無問題。
一方、another.cpp内で使用されているglobalは、定義はmain.cppでしているが、
another.cpp内で宣言していない。
だからコンパイラはanother.cppのglobalという識別子が何なのかという
情報を教えてもらってないのでエラーになる。


219:デフォルトの名無しさん
09/05/21 16:52:01
歴史というなら、それこそ5,60年代とかに遡れるんじゃね?

Wikipedia項目リンク

220:デフォルトの名無しさん
09/05/21 17:05:44
>>214
つか、それ12345FGHIJKLMNって表示されないか?
処理系依存なんかな。

221:デフォルトの名無しさん
09/05/21 21:03:52
すまん質問させてもらう

void *operator new(size_t size,const char *pname, int nline );
#define new new(__FILE__, __LINE__)

とnewを実行したソース名と行数を取ってるんだが
これのdelete版が出来ない
もしかしてdeleteの方は無理?
STL使ったら、妙なdeleteが増えて特定したいんだ

222:デフォルトの名無しさん
09/05/21 21:43:31
>>220
処理系っつーか、出力装置 (と、その状態) による。

223:デフォルトの名無しさん
09/05/21 22:21:07
MFCを使ってライブラリを利用するのと
SDKで一からアプリケーションを作成するのは
どちらがいいでしょうか?

224:デフォルトの名無しさん
09/05/21 22:27:33
MFC。間違いない。マクロやキャスト使いまくりで興奮する。

225:デフォルトの名無しさん
09/05/22 00:48:32
最初のうちはSDKで必死になって窓の基本を覚え、その後MFCをさわって逝く

まあ俺のことだが

226:205
09/05/22 01:07:35
>>218
やっと理解できたー!有難う。
というわけで俺んなかでの結論;
「extern就職誌をつけられた変数・関数はこのファイルでこれから使うけどどっか別のソースファイルで
指定されてるからね!ちなみに関数のプロトタイプがあるとしたらそれはextern就職誌つけなくてもそれは
externとみなされてるから、別のファイルで指定されてるかもしんないし、ひょっとするとこのファイルの
後で定義されてるかもしんない」

という感じか。
なんか認識にまだ問題有ったら指摘して

227:デフォルトの名無しさん
09/05/22 11:00:27
就労意欲は汲み取れた。

228:デフォルトの名無しさん
09/05/22 11:55:10
ワロタ

229:デフォルトの名無しさん
09/05/22 15:31:37
まずはexternなしでソースを書いてコンパイルしてエラーが
出たらexternをつければよい

230:デフォルトの名無しさん
09/05/22 16:45:03
そもそもexternって使う機会あんまなくないか?

231:デフォルトの名無しさん
09/05/22 17:56:56
グローバル変数

232:デフォルトの名無しさん
09/05/22 17:59:49
グローバル変数そのものをほとんど使わないからな

233:デフォルトの名無しさん
09/05/22 18:32:07
グローバル変数を使うとしても、
初期化の問題を恐れてほとんど全部
関数スコープ内でのstatic変数の参照の呼び出しにしちゃうし
(つまり結局グローバルスコープではない。)



234:デフォルトの名無しさん
09/05/22 18:39:49
グローバル変数でもグローバル変数を入れるクラスを作るからね

235:デフォルトの名無しさん
09/05/22 19:22:42
グローバル変数がグローバル関数になり、グローバル関数がグローバルオブジェクトになるわけですね。

236:デフォルトの名無しさん
09/05/23 09:48:22
template <int N> foo bar(Hoge hoge1, Hoge hoge2, … , Hoge hogeN)
みたいな感じでtemplate <int N>のNに対応して引数の数を変える関数とかって標準で作れますか?

237:デフォルトの名無しさん
09/05/23 10:04:52
多重定義しかありません

238:デフォルトの名無しさん
09/05/23 12:05:47
可変引数リストじゃだめなんだろうか

239:デフォルトの名無しさん
09/05/23 12:21:57
Cを使ってlsライクなプログラムを作ろうとしてて、自分の環境下で動いているlsコマンドの動作を元に作ろうと思ってるんだけど
ls-オプションの動作のCで書かれたソースはコンピュータ内にあるのでしょうか?

240:デフォルトの名無しさん
09/05/23 12:38:52
引数の個数が変化すれば bar() の中身も変える必要があるしね

241:デフォルトの名無しさん
09/05/23 12:48:05
>>239
lsは、Coreutilsに含まれているはずだから
URLリンク(www.gnu.org)
から手に入れることができるはずだよ

242:デフォルトの名無しさん
09/05/23 13:22:25
今加速度センサから値を得て速度を出してるんですが、ノイズや誤差の影響で
加速度を積分した値が静止させても0に戻りません。
そこで出来るだけ正確に無理矢理0に戻そうとしているんですが、何かいい方法ありませんか?
あと、このようなフィルタ処理?とかを扱ってるスレってありますか?

243:デフォルトの名無しさん
09/05/23 15:12:40
getopt

244:デフォルトの名無しさん
09/05/23 18:32:35
C/C++でHTMLのパーサってないでしょうか?

245:デフォルトの名無しさん
09/05/23 21:26:05
なんでop[]は引数をひとつしか取れないようにしたんだろう

246:デフォルトの名無しさん
09/05/23 21:34:12
>>245
ハゲに聞いてくれ

247:デフォルトの名無しさん
09/05/23 21:45:27
>>245
C++はPascalじゃないよ
[a, b]なんて書き方はないから

248:デフォルトの名無しさん
09/05/23 21:53:10
何をブチ込んでもいいんだから
気が済むまでメンバ変数詰め込んだクラスを引数にとる[]を定義すればいいじゃないか

249:デフォルトの名無しさん
09/05/23 22:03:42
delete a, b;
とかやるのと一緒だな>>247

250:246
09/05/23 22:09:52
>>247
別に>>245はPascalとごっちゃにしているわけではないだろう。
オペレータオーバーロードとしては[a, b]の形も認めてもいいんじゃないかって
>>245は言いたいんじゃないの?

251:デフォルトの名無しさん
09/05/23 22:24:41
C++はカンマ演算子の意味が違うから無理
関数呼び出しはむしろ特別な場合

252:246
09/05/23 22:28:16
>>251
そりゃ知っているけどさ、
出来たら便利じゃない。
今からじゃ互換性の関係があって無理だけど、
最初の段階で可能であるように仕様を定めておけばよかったのでは。

・・・ということも踏まえた上で、
だから俺は「ハゲに聞いてくれ」と言ったのだ。

253:デフォルトの名無しさん
09/05/23 22:31:00
C言語で連立方程式を解くにはどんな方法がありますか?
2次方程式だけじゃなく3次4次と応用が利くようなやり方で

254:デフォルトの名無しさん
09/05/23 22:32:35
>>253
Gaussの消去法でぐぐれ

255:デフォルトの名無しさん
09/05/23 22:35:21
あほか
ガウス法は一元一次方程式にしか使えん
反復法なら使える

256:デフォルトの名無しさん
09/05/23 22:35:38
もしかして: ガウスの消去法

257:デフォルトの名無しさん
09/05/23 22:36:27
掃き出し法だろ常考

258:デフォルトの名無しさん
09/05/23 22:45:46
お前ら・・・(汗

3次とか4次にも使えるようにって書いてあるのが読めないのか?

259:デフォルトの名無しさん
09/05/23 22:46:09
Gauss-Seidel反復法マジオススメ

260:デフォルトの名無しさん
09/05/23 22:57:23
反復法で10万次方程式解いて悦にひたるのがマイブーム

261:デフォルトの名無しさん
09/05/23 23:02:55
long num=100;
このとき
++(++(++(++num)));
って動作は未定義になりますか?
一つの式の中で値が複数回変更されているように見えるのですが。

262:デフォルトの名無しさん
09/05/23 23:04:42
>>261
ならない
カッコがついているので副作用完了点がカッコの中で終了するから

263:261
09/05/23 23:14:35
>>262
となると、自作クラスの前置インクリメント演算子のオーバーロードの返り値は、
const参照で*thisを返すのではなく
非constな参照で*thisを返すべきなのですね。
ありがとうございました。

264:デフォルトの名無しさん
09/05/23 23:15:13
>>261
そもそも
++(++foo)
は、++fooが評価後に値なので、++を作用させることができない気がするのだが
これがC++の参照返す++演算子のオーバーロードならどうなるか知らないけど

265:261
09/05/23 23:19:51
>>264
でも一応
long num=100;
++(++(++(++num)));
はコンパイル可能です。

266:デフォルトの名無しさん
09/05/23 23:20:04
Cでは前置も後置も値のコピーを返すけど
C++の前置は自身を左辺値として帰すので有効。

267:デフォルトの名無しさん
09/05/23 23:24:35
ああ、cとc++では扱いが違ったのですね。
c++脳なので知りませんでした。


268:デフォルトの名無しさん
09/05/24 10:29:25
HTMLパーサ自作できたのだわ
1時間もかからなかったのだわ
こんなに簡単なのでググってもでないわけだわ

JAVA, Ruby でパーサ使ってる奴って・・・

269:デフォルトの名無しさん
09/05/24 12:02:03
+は可算演算子だよね。

では%は何演算子と呼べばいい?


270:デフォルトの名無しさん
09/05/24 12:05:10
剰余演算子

271:デフォルトの名無しさん
09/05/24 12:14:19
>>268

天才だな

272:デフォルトの名無しさん
09/05/24 12:46:43
よく言われる

273:269
09/05/24 13:00:27
>>270
ああなるほどね。
ありがと。

274:デフォルトの名無しさん
09/05/24 13:14:03
そこらへんのパーサって非標準(タグ閉じ忘れとか含め)のHTML読めるの?

275:デフォルトの名無しさん
09/05/24 14:24:58
STLの投げる例外の一覧みたいなサイトってありますか?

276:269
09/05/24 14:39:30
+num

-num
といった、符号をあらわす演算子はなんて言えばいい?
単項演算子じゃおかしいし、符号演算子とか??

277:デフォルトの名無しさん
09/05/24 14:44:18
性符号・フフ郷

278:デフォルトの名無しさん
09/05/24 14:51:04
>>277
サンクス!

279:デフォルトの名無しさん
09/05/24 17:02:00
int foo(bool arg1, bool arg2)
{
if(arg1){return 1;}
else if(arg2){return 2;}
else return 3;
}
この関数をこれ以上速く記述することって可能でしょうか?
例えばelseを無くしたりすることによって。



280:デフォルトの名無しさん
09/05/24 17:15:45
速く記述する、ってどういうこと?
短くの間違い?

281:デフォルトの名無しさん
09/05/24 17:19:50
>>279

int foo(bool arg1, bool arg2)
{
return arg1 ? 1 : arg2 ? 2: 3;
}


282:デフォルトの名無しさん
09/05/24 17:32:52
static int f[][] = {{3, 2}, {1, 1}};
int foo(bool arg1, bool arg2){
  return f[arg1][arg2];
}

283:デフォルトの名無しさん
09/05/24 17:46:34
static int* f = {3, 2, 1, 1};
int foo(bool arg1, bool arg2){
  ASSERT((!!arg1) == arg1 && (!!arg2) == arg2);
  return f + ((arg1 << 1) | arg2);
}

284:デフォルトの名無しさん
09/05/24 17:47:21
>>279

速くするんだったらinline asmかな
やり方知らんから教えられないけど

285:279
09/05/24 18:06:32
>>280
速く動作するように記述したいという意味です。
確かに速記でもするかのような書き方でした。

>>281-283
ありがとうございます。

>>284
ありがとうございます。
一応標準C++だけで書きたいと思っております。


みなさんありがとうございます。
連続質問で申し訳ないのですが、
int bar(bool arg1, bool arg2)
{
if(arg1&&arg2){return 1;}
else if(arg1||arg2){return 2;}
else return 3;
}
でしたらどう記述するのが(動作速度的に)ベストでしょうか?

286:デフォルトの名無しさん
09/05/24 18:11:24
前のもそうだがその程度ならそのまま書くのが一番良いと思う。
特定の環境を想定しないのなら尚更だ。

287:デフォルトの名無しさん
09/05/24 18:12:35
>>286
たしかに、ボトルネックにならないなら素直な書き方が一番ですかね。
ありがとうございました。

288:デフォルトの名無しさん
09/05/24 18:15:00
ここ行けば、そういうの好きな人いっぱい居るぞ。
スレリンク(tech板)

俺は面倒くさいからパス。

289:デフォルトの名無しさん
09/05/24 20:14:35
数人の身長が記されているtxtファイルを読み込んで、

140 ー 145cm **
145 ー 150cm *
150 ー 155cm **
155 ー 160cm **
160 ー 165cm ****
165 ー 170cm **

の、ようにヒストグラムで出力するプログラムの作り方を教えてください。

290:デフォルトの名無しさん
09/05/24 20:17:07
読み込んで出力すればいいよ

291:デフォルトの名無しさん
09/05/24 21:35:54
>>289
1.テキストファイルを読み込む
2. int配列にそれぞれの範囲の要素を加算していく
3 配列の要素の値の数だけ*を表示する。

順番に作っていけばいい。


292:287
09/05/24 21:47:55
>>288
ありがとうございます。
・・・ボトルネックになるようでしたら挑戦してみます。

293:デフォルトの名無しさん
09/05/24 21:49:47
float A[4][21];
でA[2]とA[4]を入れ替える方法教えてください

294:デフォルトの名無しさん
09/05/24 21:56:24
>>293
std::swap(A[2][x],A[4][x])
でxを0〜21まで回せばいいんじゃない?


295:デフォルトの名無しさん
09/05/24 21:58:01
for(int i = 0; i < 21; i++){
float t = A[2][i];
A[2][i] = A[4][i];
A[4][i] = t;
}

296:デフォルトの名無しさん
09/05/24 21:58:36
普通にmemcpy3回じゃない?
ビットスワップでもいいけど

297:デフォルトの名無しさん
09/05/24 22:03:43
どうかなぁ。並列化考えたらmemcpyは不利な気がした。

298:デフォルトの名無しさん
09/05/24 22:09:07
どのデーター量なら>>295が一番早い

299:デフォルトの名無しさん
09/05/24 22:14:08
d 一個一個交換する方法でやってみます

こんな風にしてたんだけど何故か変な値になっちゃうんだよね。
memcpy(B,A[i],sizeof(float)*(n+1));
memcpy(A[i],A[i+j],sizeof(float)*(n+1));
memcpy(A[i+j],B,sizeof(float)*(n+1));

300:デフォルトの名無しさん
09/05/24 22:15:50
A[4][n+1]; B[n+1];としてね

301:デフォルトの名無しさん
09/05/24 22:16:02
クラスの2次元配列を用いるにはどう宣言すればよいでしょうか
具体的には、
class Complex {
public:
double re;//実部
double im;//虚数部
};
という複素数のクラスを用いて行列を作成したいのですが、メインで
#define SIZE 5
int main(){
Complex **comp_mat;
comp_mat = new Complex[SIZE][SIZE];
}
のようにしますと(*)[5]型は**型に変換できませんとエラーが出ます。

どのようにすればいいのかわからないので1次元で宣言して以下のように
アクセスしていました。(comp + i * SIZE + j )の記述がわかりにくいので
簡単にしたいのですが、よろしくお願いします
int main(){
int i , j ;
Complex *comp_mat ;
comp_mat = new Complex[SIZE*SIZE] ;
//compを(-1 , -1)の値で埋める
for( i = 0 ; i < SIZE ; i++ ){
for( j = 0 ; j < SIZE ; j++){
(comp + i * SIZE + j ) ->re = -1.0 ;
(comp + i * SIZE + j ) ->im = -1.0 ;
}
}
・・・・省略・・・・
}

302:デフォルトの名無しさん
09/05/24 22:20:57
>>291
ありがとうございます

303:デフォルトの名無しさん
09/05/24 22:42:23
>>293
std::swap(A[2],A[4])はどう?

304:デフォルトの名無しさん
09/05/24 22:52:58
C++で
fout << "Hello World" << endl ;
などでファイル書き込みができますが、
foutで複数ファイルへの書き込みを区別するにはどうすればいいのでしょうか

FILE *f_eng_p , *f_jpn_p ;
fprintf( f_p , "Hello World ") ;
fprintf( f_s_p , "こんにちは 世界") ;
のようにファイルポインタを2つ宣言してfprintfで行うのでしょうが、
fprintfは記述がめんどくさいのでどなたか知恵をお貸しください

305:デフォルトの名無しさん
09/05/24 22:54:40
すみません、上の f_p と f_s_p は以下の間違いです
FILE *f_eng_p , *f_jpn_p ;
fprintf( f_eng_p , "Hello World ") ;
fprintf( f_jpn_p , "こんにちは 世界") ;

306:294
09/05/24 23:04:25
>>303
配列へのポインタだから無理だろ。
だから>>294を提唱するぜ。

307:デフォルトの名無しさん
09/05/24 23:04:51
>>304
出力ストリームを複数持てばいいだけじゃないの?

308:デフォルトの名無しさん
09/05/24 23:15:46
>>303
それだとエラーでちゃいます。swap(A[2][x],A[4][x])の方法で上手くうごきました。
あと、すみませんがもう一つ質問お願いします。

void func(二次元配列を受け取る){
  処理
}

int main(){
  float A[x][y];
  A[0〜x][0〜y]に値を代入;
  func(?);
  return 0;
}

ここで関数funcはA[4][5]でもA[99][99]でもどんな大きさの二次元配列でも
受け取れるようにしたいんですが、関数funcの宣言の引数と、main関数内で
関数funcに渡す引数はどのようにすればいいですか?

309:デフォルトの名無しさん
09/05/24 23:29:22
それは無理なので
std::vector< std::vector< float > >
使っとけ

310:デフォルトの名無しさん
09/05/24 23:33:40
void func(float *a, int m, int n){
 処理
}

int main(){
  float A[x][y];
  A[0〜x][0〜y]に値を代入;
  func((float*)A, x, y);
  return 0;
}


311:デフォルトの名無しさん
09/05/24 23:34:59
ありがとうございます。無理なんですね。どうりで調べてもA[][5]とかしか出てこないわけだ
C言語でしたいのでA[]にしてA[y*x+y]でアクセスすることにします。

312:デフォルトの名無しさん
09/05/24 23:45:01
>>311
前にも同じような質問が出ていましたが、最近のCの規格では

void func (int m, int n, float a[m][n]) { 処理 }

といった書き方ができますよ。mとnは呼び出し側で決められます。

【初心者歓迎】C/C++室 Ver.65【環境依存OK】
スレリンク(tech板)
>>836 あたりからの書き込みにも情報があります。

313:デフォルトの名無しさん
09/05/24 23:57:32
>>312
これは知らなかった。でも、VS2008でやってみたらエラー出て無理だった

314:デフォルトの名無しさん
09/05/24 23:59:01
マイクロソフトはC99シカトしてます。

315:デフォルトの名無しさん
09/05/25 00:04:33
0Xどうするんだろうね。

でも、C++/CLIはもはやC++なのかどうなのかも怪しいw

316:デフォルトの名無しさん
09/05/25 00:19:10
>>314
VS2010でauto、decltype、λ式、右辺値参照、static_assertは取り敢えず入れる
予定だそうだ

それ以上のC++0x対応は今の所未定

317:デフォルトの名無しさん
09/05/25 00:29:27
C++ なんだから配列には vector 使おうよとか
配列の配列をポインタのポインタに置き換えられないことは
大概の教科書で懇切丁寧に説明しているはずなのでもう一度教科書読んでねとか
全力でマクロは避けろ( C++ Coding standards )とか
なぜに FILE 構造体?とか

いろいろ思った^^

318:デフォルトの名無しさん
09/05/25 00:37:58
>>317
その辺りはD&Eを読んでもらえば歴史的経緯がよくわかる

Cは一人、いや二人の人間が独善で作った言語だが
C++はコミュニティに属する数多くの人の意見を元に作られてる

中心人物は禿だったがもはや禿が一人で作ったC++とは絶対に言えまい

319:デフォルトの名無しさん
09/05/25 00:45:46
>>301
動的二次元配列の作成と削除は
Complex **comp_mat = new Complex *[SIZE];
for ( size_t i = 0; i != SIZE; ++i )
comp_mat[i] = new Complex();
for ( size_t i = 0; i != SIZE; ++i )
delete [] comp_mat[i];
delete [] comp_mat;

でも、C++でこんなことしちゃらめ。

320:デフォルトの名無しさん
09/05/25 00:58:46
>>319
なんでダメなの?
俺はよく使ってるぜ
コンストラクタとデストラクタにぶち込んでおけば十分じゃん

vectorを使う事もあるけど少なくとも速度が最大要求の
科学技術計算では>>319の方法をよく使うぞ

321:デフォルトの名無しさん
09/05/25 01:13:03
速度重視ならクラスで包んじゃダメでしょ。

・・・それはさておき、C++のモダンなスタイルは可読性重視になってるからっていう弱い理由。
もちろん、わかって使う分には問題ないよ。


322:デフォルトの名無しさん
09/05/25 01:19:41
「速度が最大要求」ならクラスはおろか関数呼び出しもNGでしょ^^
なにより new と delete 自体が遅い。
memcpy を使うほうが一般的。
どうしても C++ ライクに書きたいなら、せめて allocator クラス使おうよ。


323:デフォルトの名無しさん
09/05/25 01:22:42
memcpy じゃなくて malloc の間違いでした^^スマンコ

324:デフォルトの名無しさん
09/05/25 01:38:26
そもそも速度優先なら、そんなに頻繁にメモリの確保/解放はしない。
どうしてもって言うのなら、自前でメモリ管理する。

325:デフォルトの名無しさん
09/05/25 01:38:35
>>321-322
いや速度重視ならmallocもそのままでは使わないだろ。自前でプールとかしてさ。

326:デフォルトの名無しさん
09/05/25 01:41:30
だな。つか new 遅すぎ。

327:デフォルトの名無しさん
09/05/25 01:45:08
っていうかC++が速くない
Cより5%遅いが開発の指標だったから

328:デフォルトの名無しさん
09/05/25 01:51:20
OCN規制で携帯でしか書けないのが辛いぜ。

329:デフォルトの名無しさん
09/05/25 01:53:35
支援

330:デフォルトの名無しさん
09/05/25 02:56:08
これlj(x)の分子が0になっちゃうんだけど、これで合ってるの?

331:デフォルトの名無しさん
09/05/25 02:56:25
Wikipedia項目リンク

URL忘れてたこれ

332:デフォルトの名無しさん
09/05/25 06:04:25
なんか一気にレベル低くなってね?

333:デフォルトの名無しさん
09/05/25 09:36:57
※スレを勃てるまでもない低俗なC/C++の質問はここでお願いします

334:デフォルトの名無しさん
09/05/25 19:27:15
C++で文字列を入力し、そこに指定されていた文字が含まれている場合、そうでない場合に分けて処理を行いたいです。
どう書けばいいでしょうか?
文字列はアルファベットなのですが、
指定するすべての文字についてif,elseifで判別するしかないのでしょうか?

335:デフォルトの名無しさん
09/05/25 19:31:35
>>334
そうだよ

336:デフォルトの名無しさん
09/05/25 19:45:53
>>335
ありがとうございます。

もう一つお願いします。

たとえば、
abddみたいな文字列があって、
先頭の1文字づつ判別していきたいです。つまり、
1回目の処理はaについて、
2回目の処理はbについて・・・
のような感じです。
どう考えればいいでしょうか?

337:デフォルトの名無しさん
09/05/25 20:29:58
何をどう判別するのかわからん。
具体的な入力例と、期待される結果を示してくれ。

338:デフォルトの名無しさん
09/05/25 20:45:19
>>337
アルファベットと書きましたが、半角英数すべてで、
accaと入力したとすれば

aが1個存在するので coutで1と出力
cが2個存在するので coutで2と出力
aが1個存在するので coutで1と出力
みたいな感じです。

よろしくお願いします。

339:デフォルトの名無しさん
09/05/25 21:03:30
#include <iostream>
#include <string>
using namespace std;
int main(){
    int n = 0;
    string s;
    cin >> s;
    for(int i=0; i<s.size(); i++){
        n++;
        if(s[i]==s[i+1]) continue;
        cout << n << endl;
        n = 0;
    }
    return 0;
}

340:デフォルトの名無しさん
09/05/25 21:40:58
ファイル操作にはいろいろとエラーチェック用のメソッドが用意されてますが、例外機構をつかわない理由はあるのでしょうか?

341:デフォルトの名無しさん
09/05/25 23:11:06
例外を使いたくない環境ってのが結構あるからかも

342:デフォルトの名無しさん
09/05/26 22:31:02
C言語そのものの質問とはちょっと違うのですが#ifdef,#ifndefに対応する#endifを見つけて、
どれとどれが対応しているかのコメントを追加するようなツールは無いでしょうか?


//////////入力///////////
#if AAA
...
#if BBB
...
#endif
...
#endif

///////////出力///////////
#if AAA
...
#if BBB
...
#endif //BBB
...
#endif // AAA


343:デフォルトの名無しさん
09/05/26 23:16:37
>>342
知らないなぁ。

俺は大抵はコメントを毎回記載しちゃう派だし。
あるいはエディタの機能で対応する#〜に飛んだりするし。

良い課題として作ってみてよ。
そして是非とも公開してくれ!

344:デフォルトの名無しさん
09/05/27 17:04:28
charで配列の要素数を変数にしています。
cinで入力後、この要素数の最大値を調べたいのですがどうしたらいいでしょうか?

345:馬牛
09/05/27 17:14:21
C++です。
a=10,b=3,c=2として、!aかつb>cの戻り値、!aまたはb>cの戻り値はそれぞれどうなりますか?
よろしくです。

346:デフォルトの名無しさん
09/05/27 17:15:56
felse true

347:デフォルトの名無しさん
09/05/27 17:33:15
18時まで引っ張ろうぜw

348:デフォルトの名無しさん
09/05/27 17:44:52
>>345
君は、C++をやる前に離散数学を勉強することをお薦めする。

>>347
どこの誤爆だ

349:デフォルトの名無しさん
09/05/27 17:46:29
スレリンク(tech板:346番)
これだろ

350:デフォルトの名無しさん
09/05/27 18:03:03
https通信をOSによらずに行いたいと思っているのだが、手の込んだことするのは
面倒になりcurl.exeを呼び出すことで解決することにした。
先頭の10KBとかは読めないと思っていたら対応していた。

351:デフォルトの名無しさん
09/05/27 21:26:13
main{

func1();

}


func1{
char array[100];
array[1] = 10;

func2();

}

func2{

char sum[10];

sum[0] = array[1];
}

このようにプログラムする場合、func2にてarray[1]をセットする場合、
グローバル宣言するしかないのでしょうか?

できれば、main内でfunc1が終了した時点でarrayで使用していた変数を消滅させたいのです。
メモリ使用量を少なくする意味で

352:デフォルトの名無しさん
09/05/27 21:29:16
func2(array[1] );

353:デフォルトの名無しさん
09/05/27 21:31:49
>>350
何のことを言っているのだい?
curl.exeはWindows専用ではないのかい?

354:デフォルトの名無しさん
09/05/27 21:36:15
>>352

func1{
char array[100];
array[1] = 10;
array[2] = 5;

func2();

}
func2{

char sum[10];

sum[0] = array[1];
sum[1] = array[2];
}

こうだった場合は、func2();
の中は何になるのでしょうか?

355:デフォルトの名無しさん
09/05/27 21:39:11
>>354
参考書とにらめっこしてこい。 コードの書き方からしてお前は根本的に理解できていない。

356:デフォルトの名無しさん
09/05/27 21:48:55
すみませんお願いします

357:デフォルトの名無しさん
09/05/27 21:50:33
353
SYSTEMの中身を対応するのに変える MACでもUNIXでもあるはず
curl.hの使い方がわかればいいんだけど、メモリやファイルに読み書きするのに
専用の関数を用意しなければならず難しかった。
それなら直接exeを動かしたら簡明と思った。

358:デフォルトの名無しさん
09/05/27 21:51:13
func2(array);

359:353
09/05/27 22:57:24
>>357
UNIX系でも〜.exeって名前なの?


360:デフォルトの名無しさん
09/05/27 22:59:06
>>354
お前ふざけてんの?
何言ってるの?
スレタイ読めよ、ここはC/C++の質問部屋だぞ!!
そんな謎の言語は知りません!


361:デフォルトの名無しさん
09/05/28 02:25:31
質問します。

Windows環境で、とあるC++用ライブラリ hoge.lib があります。
このライブラリには、関数を呼び出すためのヘッダファイル hoge.h が用意されていますが、
実際のソースは提供されていないものとします。
また、ライブラリ内部だけで使われている関数は、hoge.h には記述されていないようです。

さて、このライブラリには名前空間は設定されていません。
そのままでは使いにくいので、Hoge::〜 という名前でライブラリの関数を呼び出せたら便利だと思いました。

この状況(*.h と *.lib のみ)で、ライブラリの関数に名前空間をセットすることは可能でしょうか?


362:デフォルトの名無しさん
09/05/28 06:25:28
>>361
君がhoge_ns.hとかいうヘッダを自作して、
hoge_ns.hでは
namespace Hoge
{
inline int bar(int x)
{
return bar(x);//hoge.hの。
}

//...etc
}
のようにラップしたらだめかな?

363:デフォルトの名無しさん
09/05/28 06:30:49
c/c++で仕事している人たちに質問です。
基本情報技術者試験って、最低限必要な資格ですか?

364:デフォルトの名無しさん
09/05/28 07:01:46
5000円程度で取れるんだから、とっとけ。

365:デフォルトの名無しさん
09/05/28 07:09:15
生産性と資格には関連はないだろ。
未経験なら持っていたら考慮されるとか一時金や給料がすこしだけ良くなるとかだろう。

366:デフォルトの名無しさん
09/05/28 07:18:18
>362
ありがとうございます。
諦める決心がつきそうです。

367:デフォルトの名無しさん
09/05/28 07:29:43
webページを解析したいのですが、HTMLを整形済みXMLに変換するライブラリはありますか

368:デフォルトの名無しさん
09/05/28 07:57:22
自己解決しました。 
HTMLのパーサーがあるみたいでそっちのします。

369:デフォルトの名無しさん
09/05/28 10:06:12
くわしく

370:デフォルトの名無しさん
09/05/28 10:32:40
>>366
C用のライブラリだったら
namespace hoge {
extern "C" {
#include "hoge.h"
}
}
である程度ごまかせるんだけどな。

それにusing hoge::hogedata_t
とか#pragma comment(lib)とかも使って。

371:デフォルトの名無しさん
09/05/28 17:29:11
fstream& getLogFile() {
static fstream logFile;
return logFile;
}
として、非局所的なオブジェクトのコンストラクタ内でもログを取れる用にしたんですけど、
logFileの破壊と非局所的なオブジェクトの破壊はどちらが先に起こるか決まってるんですか?
非局所オブジェクトの破壊時にもログをとるのに使えるのか知りたいので。

372:デフォルトの名無しさん
09/05/28 19:02:56
フーリエ級数展開をするプログラム を作ったんだけど異常値しか出ないのでどこが悪いか教えてください
↓のプログラムの場合はf(x)=x [xが0-5] , 0 [xが5-10] で波長が10でループするような式
//最初にxの値を入力してから
hani_suu = 2;//範囲の数
hani[0]=0.0; hani[1]=5.0; hani[2]=10.0; //(0〜5),(5〜10)という意味

double temp=0,temp_cos,temp_sin;

for(int j=0;j<hani_suu ;j++)//以下a0の計算
for(double i = hani[j];i<hani[j+1];i+=0.1)temp += 0.1 * kansuu(i,j);//積分計算   ※kansuu(i,j)はjが0のときf(x)=x,1のときf(x)=0を返す

for(int n=1;n<50;n++)//以下an,bnの計算 
{
temp_cos=0; temp_sin=0;

for(int j=0;j<hani_suu;j++)
for(double i = hani[j];i<hani[j+1];i+=0.1) //積分計算
{
temp_sin+= 0.1 * kansuu(i,j)*sin((2.0*PI*i*n)/10);
temp_cos+= 0.1 * kansuu(i,j)*cos((2.0*PI*i*n)/10);
}

cos_v[n] = temp_cos; //an
sin_v[n] = temp_sin;//bn
}

temp = temp/2.0; //以下a0+Σ(ancos+bnsin)
for(int n=1;n<50;n++)
temp = temp + cos_v[n] * cos((2.0* PI * n * x )/10) + sin_v[n] * sin((2.0* PI * n * x )/10);
//最終的なtempが答え
見にくいですがお願いします

373:デフォルトの名無しさん
09/05/28 19:05:24
勉強用に、シンプルな多倍長加算を作ってるのですが
もっとシンプルに出来ますでしょうか
効率は意識していません

string add(string l,string r){
int carry=0;
stringstream ss;
if(l.size()>r.size()){swap(l,r);}
reverse(l.begin(),l.end());
reverse(r.begin(),r.end());
int i=0;
for(;i<l.size();++i){
unsigned int tmp=(l[i]-'0')+(r[i]-'0')+carry;
if(tmp/10){carry=1;}else{carry=0;}
tmp%=10;
ss<<tmp;
}
for(int j=i;j<r.size();++j){
unsigned int tmp=r[i]-'0'+carry;
if(tmp/10){carry=1;}else{carry=0;}
tmp%=10;
ss<<tmp;
}
if(carry){ss<<'1';}
string ret=ss.str();
reverse(ret.begin(),ret.end());
return ret;
}

374:デフォルトの名無しさん
09/05/28 19:40:36
>>372
感覚で読むとfor ( ; i<hani[j+1]; )が臭うコードに見える。

>>373
C++は、よくわからないが、やりたいことはなんとなく伝わる。
for()は、二つに分ける必要があったのかな。
似たようなことをしているから、for()のなかで、if()するようなコードが浮かびそう。
引数を参照にしたり、const char *foo = bar.c_str()で添字アクセスとか
ただの高速化だけど。

375:デフォルトの名無しさん
09/05/28 20:17:36
ヘッダファイルでプログラムソースファイルを分割することができますが
ヘッダファイルも分割する方法があったら教えて下さい

376:デフォルトの名無しさん
09/05/28 20:20:20
ヘッダファイルはいくらでも分割できます。

377:デフォルトの名無しさん
09/05/28 20:38:31
VC++2008を使ってるのですが
自動修復情報の保存ってのが左下にでてしょっちゅう重いです
なんですかこれ

378:デフォルトの名無しさん
09/05/28 20:59:40
事故解決
URLリンク(blog.goo.ne.jp)

379:デフォルトの名無しさん
09/05/28 21:38:47
実際の数学みたいにxを数字にせずxとして計算するにはどうしたらいいですか?
例えば2x*3x=6x^2みたいな感じで計算して、あとで6x^2のxに色々な数字を代入
できるようにしたいんですが

380:デフォルトの名無しさん
09/05/28 21:54:57
関数電卓のソースを探して見てみよう!

381:デフォルトの名無しさん
09/05/28 22:08:34
ある関数内でnewして得たアドレスを返り値にして
それを外で受け取ったらそのまま、受け取らなかったらdeleteする
みたいな記述はどうやったらできますか?

382:デフォルトの名無しさん
09/05/28 22:39:54
>>381
受け取らなかったらとは、どういう状態?

383:デフォルトの名無しさん
09/05/28 22:50:55
>>382
pHoge = allocHoge(); // OK

allocHoge(); // 自動でdelete したい!

384:デフォルトの名無しさん
09/05/28 23:01:55
>>383
生のポインタじゃムリじゃね?
スマートポインタを使うとか。

385:デフォルトの名無しさん
09/05/29 00:23:19
wrap_allocHoge( void* p )的なものを外側に作って
p==NULLならそのまま削除
p!=NULLなら入れて返すとか


386:デフォルトの名無しさん
09/05/29 00:34:41
>>383
C++なら>>385に引数無しの関数をオーバーロードするのもアリだと思う

387:372
09/05/29 04:19:06
>>372では
for(double i = hani[j];i<hani[j+1];i+=0.1)temp += 0.1 * kansuu(i,j);//積分計算 
こんな風に小さい範囲を刻んで積分計算してるんですが
もっと精度を上げたり計算量を少なくするためにはどんな方法がありますか?

388:デフォルトの名無しさん
09/05/29 05:51:59
>>387
完全にスレ違いだろ。
数学スレに行ってくれ。

389:デフォルトの名無しさん
09/05/29 07:16:23
RPGの戦闘部分を作っています。
FFみたいなアクティブタイムバトル(パラメータのすばやさに毎秒1ずつ足して行き、規定値になったら行動)
というものですが、勝利判定はどこでどういう風にすればよいでしょうか?

行動が終わった時に、goto文で戦闘部分の処理を抜け出すのが一般的でしょうか?

390:デフォルトの名無しさん
09/05/29 07:24:55
goto文が一般的じゃない。break使え

391:デフォルトの名無しさん
09/05/29 07:48:35
>>390
ありがとうございます。危うく道を踏み外すところでした

392:デフォルトの名無しさん
09/05/29 19:50:28
STLにupper_boundとlower_boundってありますが
lower:指定した値"以上"の値が最初に現れる位置を返す
upper:指定した値"より大きい"の値が最初に現れる位置を返す
となっていて、どちらも指定した値以上の値が帰ってきます。

そうではなくて、指定した値を超えない最大の値を得たい場合
アルゴリズムを組み合わせたりして
それを簡単に行うような方法ってありますでしょうか

具体的に言うと
1 7 10という列に対して
upper/lower_boundに値2を与えると
どちらも7が帰ってきますが、
1が帰ってくるアルゴリズムはありますか

393:デフォルトの名無しさん
09/05/29 20:06:26
デクリメントすれば?

394:392
09/05/29 20:24:57
自己解決しました
find_if(v.begin(),v.end(),bind2nd(less<int>(),n));

395:392
09/05/29 20:38:47
すみません、解決していませんでした
デクリメントってこういうことでしょうか
vector<int>::iterator it = lower_bound(v.begin(),v.end(),n);
--it; //ここ(*)
int lower = *it;

確かにこれで期待した動作はするのですが
ちょっと気になるのは
(*)の箇所でイテレータが範囲外、例えばitが最初の要素だったりした場合
どう範囲チェックすれば良いのでしょうか
if(it)やif(it!=NULL)などは型チェックが通りませんし

396:デフォルトの名無しさん
09/05/29 21:07:16
begin()でもrend()でも使えばいいじゃない

397:デフォルトの名無しさん
09/05/29 21:43:34
includeファイルが増えてくると面倒なので
include_iroiro.h----------
#include "foo.h"
#include "bar.h"



#include "hoge.h"
----------------------
のように、よく使うものを全部includeするヘッダを使ってます
この場合includeしたcppで実際には使わなかったクラスなども無意味にコンパイルされるんでしょうか?

398:デフォルトの名無しさん
09/05/29 21:46:39
.h ということならYES


399:デフォルトの名無しさん
09/05/29 21:55:46
そうなんですか・・・ショック!

400:デフォルトの名無しさん
09/05/29 22:05:33
プリコンパイルヘッダを使えばいい

401:デフォルトの名無しさん
09/05/29 22:11:28
450 step -1 until 1 do
ってどういう意味ですか?

402:デフォルトの名無しさん
09/05/29 22:15:57
450が1なるまで-1しながらdo以下の処理を繰り返す??

403:デフォルトの名無しさん
09/05/29 22:23:14
while(条件){
cin >> x1 >> x2;
(以下if文)

のように記述して、ループさせています。
EOFでwhileのループを終了させたいとき条件はどう書いたらいいのでしょうか?

よろしくおねがいします。


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

5394日前に更新/231 KB
担当:undef