C言語なら俺に聞け( ..
[2ch|▼Menu]
331:327
09/10/14 09:18:10
>>328
ありがとうございます。qsort関数は、検索してint型のソートなら良さげなサンプルが見つかったのですが、float型のものは見つからず仕様も良く分からなくて困っています。

332:デフォルトの名無しさん
09/10/14 09:57:31
int compare(const void *p1, const void *p2) |
 float f1 = *(float *)p1, f2 = *(float *)p2;
 if (f1 == f2)
  return 0;
 return f1 > f2 ? -1:1;
}
int main() {
 float data[] = { ... };
 qsort(data, sizeof(data)/sizeof(data[0]), sizeof(data[0]), compare);
 ...
}

333:デフォルトの名無しさん
09/10/14 10:01:23
まあそれだとNaNが含まれてるときソートできないな


334:デフォルトの名無しさん
09/10/14 10:04:10
NaNとかなる

335:デフォルトの名無しさん
09/10/14 10:17:48
NaNってC言語の比較内で判定できるのか

336:デフォルトの名無しさん
09/10/14 10:31:07
C99ならできる

337:デフォルトの名無しさん
09/10/14 10:36:07
C99なら △
C99では ○
C99においては ◎

338:デフォルトの名無しさん
09/10/14 10:45:48
>int型のソートなら良さげなサンプル
2項を引き算してたりしてw

339:デフォルトの名無しさん
09/10/14 11:05:31
>>337
それは意味が変わっているだろ。

「C89ではNaNを正しく扱えないが、C99において*なら*できる」
の省略としての「C99なら」なのだから「なら」を取ってしまってはいけない。

340:デフォルトの名無しさん
09/10/14 11:52:04
>>339
素直にC89ではできないと述べれば良い

341:デフォルトの名無しさん
09/10/14 12:02:42
>>340
C90わすれてますよ

342:デフォルトの名無しさん
09/10/14 12:11:15
sizeof(long)==sizeof(float) なら、これでも比較できる

int float_compare(const void *a, const void *b){
const long *p, *q;

p=a;
q=b;
if(*p<*q) return -1;
if(*p>*q) return 1;
return 0;
}

343:デフォルトの名無しさん
09/10/14 12:15:55
floatのときとlongのときとで大小関係が一致することは確実なの?

344:デフォルトの名無しさん
09/10/14 12:30:58
float のフォーマットに依存しないかい?
IEEE754 だと、上位から 符号 指数部 仮数部 の並びだけど… うまくいくのかな?

345:デフォルトの名無しさん
09/10/14 12:35:08
10分置きに実行するってのは
Sleep(600000);でいいの?

346:デフォルトの名無しさん
09/10/14 12:44:10
だめ
それだと10分+αになる
αの長さは不定

347:デフォルトの名無しさん
09/10/14 13:44:10
>>342-343
駄目に決まってるだろ

348:デフォルトの名無しさん
09/10/14 13:48:02
ソート順なんでもいいみたいだからいいんじゃね
処理系依存の何らかの順番でソートされるであろう

349:デフォルトの名無しさん
09/10/14 13:53:59
大小関係に矛盾があると未定義の動作だぜbaby

350:デフォルトの名無しさん
09/10/14 14:47:41
>>349
数値としての大小関係に一致するかはともかく、
大小関係を定義するcompare関数としての動作に矛盾はないかと?

351:デフォルトの名無しさん
09/10/14 14:57:51
>>349
compare(p1,p2) が 正の値を戻すとき
compare(p2,p1) が負の値を戻さないのなら そうだろうね

352:デフォルトの名無しさん
09/10/14 19:46:18
#define TEST 1
#define TEST2 2
#define TEST3 3

こんなことをして
プログラムの中で、TEST3 を使ってみたのですが
期待通りTEST3は3に置き換えられていました。

ふと、TESTは1に置き換えられるから、TEST3は13になったりしないのかと
思ったのですが、なぜ大丈夫だったのでしょうか?

353:デフォルトの名無しさん
09/10/14 19:47:57
>>352
識別子単位だから

354:デフォルトの名無しさん
09/10/14 19:52:54
cppはちゃんと考えて置換してくれるんだよ

355:デフォルトの名無しさん
09/10/14 20:12:08
今まで色んなライブラリを作ってきたんだけど、それらの機能を統合したライブラリを作りたいんだ。
でも、ただ一緒にしようとしたら、.libファイルが無駄に多くなって使いづらくなっちゃって…
この多くの.libファイルを一つの.libファイルにまとめたいのだが、何か方法はないかな?

開発環境はVisual Studio 2008 (Visual C++)で、出来れば嬉しい。
前作ったプロジェクトは、ライブラリが完成した後にHDDの整理で消してしまってるから、もうないんだ。

356:デフォルトの名無しさん
09/10/14 21:46:36
>>352
1パスだから

357:デフォルトの名無しさん
09/10/14 23:32:48
URLリンク(codepad.org)
教科書どおりに書いたらエラー出やがった。
マジ糞だろ俺の頭

ちなみに作りたいものがあってかなりすっ飛ばしたため
自分でも意味がわかっておりません。

誰か解説してください

358:デフォルトの名無しさん
09/10/14 23:38:01
>>357
教科書のタイトルと、今使ってる処理系の名前かけよ

359:デフォルトの名無しさん
09/10/14 23:42:57
>>357
どんなエラーが出たのかも言わずに解説しろとな?
codepadのエラーからエスパーすると「conio.hが無い」ってエラーが出てるじゃんとしか言いようがありません。


360:357
09/10/14 23:46:09
よっしゃ
教科書
「すぐわかるC/C++」塚越一雄

エラー
「error C3861: 'get_charset': 識別子が見つかりませんでした」

ちなみに環境はvisualc++2008exedition

361:デフォルトの名無しさん
09/10/14 23:48:12
知らんけど、本のどこかにget_charsetの定義あるだろ。探せよ

362:デフォルトの名無しさん
09/10/14 23:50:11
そうだね、飛ばすという発想がそもそも間違っていたと反省中。
地道に勉強します

363:デフォルトの名無しさん
09/10/14 23:53:14
飛ばすとかじゃなくてコピペしてくるコードが足りないだけだろうが……

364:デフォルトの名無しさん
09/10/15 00:21:28
C++ スレの二の舞か
答えない奴は説教もするな

365:デフォルトの名無しさん
09/10/15 00:24:13
整数値を入力してください:33

3-->6-->9-->12-->15-->18-->21-->24-->27-->30-->33-->

って感じのプログラムを書かないけないんだが誰か教えてくれ。
for?とかなんかそういうのを使ったりしてるんだが全くできねえ。
33ってのは入力した数で、その入力した数までの三の倍数が表示されないといけないらしい・・・



366:デフォルトの名無しさん
09/10/15 00:25:26
>>365
そんな事は無いよ、表示されなくていいよ。

367:デフォルトの名無しさん
09/10/15 00:32:41
宿題なら宿題スレへ

368:デフォルトの名無しさん
09/10/15 00:45:40
ふつーに、
3から始めて、33以下である間、3ずつインクリメント

369:デフォルトの名無しさん
09/10/15 01:09:42
最近の小学校ってこんな高度な授業があるのか。
大変だな。

370:デフォルトの名無しさん
09/10/15 01:10:49
マイクロソフトロックされるのですがどうしたらいいでしょうか?

371:デフォルトの名無しさん
09/10/15 01:11:13
scanf("%d",&a);

a = a/3;
for(b=1;b<=a;b++){
printf("%d-->",b*3);
}

372:デフォルトの名無しさん
09/10/15 01:24:49
できたぜ!
まさか答えてくれる人がいるとは・・・
本当にありがとうございます!!!

373:デフォルトの名無しさん
09/10/15 01:37:52
int i, n;
scanf("%d", &n);
for(i=3; i<=n; i+=3) printf("%d-->", i);

374:デフォルトの名無しさん
09/10/15 01:57:02
setvbuf()ってどういうときに使うの?

375:デフォルトの名無しさん
09/10/15 01:59:57
>>374
man setbuf

376:デフォルトの名無しさん
09/10/15 03:13:49
>>375
vが抜けてる?

377:デフォルトの名無しさん
09/10/15 07:13:23
基本の教科書の内容をクリアして、応用に入るためのわかりやすい参考書あったら教えてください。

378:デフォルトの名無しさん
09/10/15 08:13:42
何に応用しようとしてるのかが分からないと、勧めようがない。

379:デフォルトの名無しさん
09/10/15 10:01:40
>>376
あってるだろ

380:デフォルトの名無しさん
09/10/15 13:37:14
specificationとusageは別物だと思うが

381:デフォルトの名無しさん
09/10/15 19:27:54
>>378
特に無いんですが、もっとCに詳しくなりたくて・・・

382:デフォルトの名無しさん
09/10/15 19:35:20
>>381
オラ入りでも買っとけ

383:デフォルトの名無しさん
09/10/15 23:01:53
>>381
実際に何かソフトを作ってみれば自然と詳しくなる
何か便利なツールが欲しくなったとき、誰かが作ったフリーウェアを探すんじゃなくて自分で作ることをまず考える

384:デフォルトの名無しさん
09/10/15 23:18:14
CではCPUをOCするソフトは作れないんですよね?

385:デフォルトの名無しさん
09/10/15 23:31:29
ちょっとハードいじる必要があるが不可能ではない

386:デフォルトの名無しさん
09/10/15 23:38:37
そうんですか。インターフェースって雑誌でそれが出来ないのがCの弱点みたいなことが
書いてあったんで。まだレベル的に意味がよく分からないんですけど

387:デフォルトの名無しさん
09/10/15 23:44:20
その雑誌だとどの言語ならそれができると書かれていたの?

388:デフォルトの名無しさん
09/10/15 23:45:43
Pascalです

389:デフォルトの名無しさん
09/10/15 23:46:04
いや、C入門の特集だったんで。大学の図書館のやつで
まだ組み込みはやる気ないんでちゃんと読んではいないです

390:デフォルトの名無しさん
09/10/15 23:48:07
コンピュータの中、ソフトウェアのレベルでは何でも出来るんだけどって話かな。
個人的にはC言語で飯が炊ければと・・・

391:デフォルトの名無しさん
09/10/16 00:03:44
最近のOCって、BIOSで設定変えるだけだったりするよね。
昔はハード的に別クロック入れてたけど。

392:デフォルトの名無しさん
09/10/16 00:33:00
正確にはOCとは書いてなかったんですけど、たぶん>>390みたいな話だと思います

393:デフォルトの名無しさん
09/10/16 01:43:09
Pascalだとできるというのがよく分からんのだけど、まあそうなんでしょう

394:デフォルトの名無しさん
09/10/16 01:53:32
>>388は違う人です

395:デフォルトの名無しさん
09/10/16 07:13:35
>>390
炊飯ジャーのプログラムはCだっったりするんじゃないの


396:デフォルトの名無しさん
09/10/16 08:27:03
>>395
現状自分でプログラムできないよねってこと。
外出先から携帯でもつかって、自宅の飯の支度ができたら楽だと思うんだ。

397:デフォルトの名無しさん
09/10/16 08:37:53
おいしく炊くのは難しいかもしれないけど、
ちょっと古いタイプの炊飯器なら個人でも制御できると思うよ
高校の時にポケコンで制御してるやつがいた

398:デフォルトの名無しさん
09/10/16 09:10:21
「CPUをオープンコレクタする」って何じゃい、と一瞬考えてしまった。

399:デフォルトの名無しさん
09/10/16 09:38:21
cosの計算をするプログラムなんですけど
#include <stdio.h>
#include <math.h>

main(){


double a,b;


scanf("%lf",&a);
b=cos(a);
printf("b=%lf",b);

}
正確に計算してもらえません
どこがいけないのでしょうか?

400:デフォルトの名無しさん
09/10/16 09:49:13
>>399
単位が何なのかわかってないだろ

401:デフォルトの名無しさん
09/10/16 10:41:45
>>399
取り敢えず、0を入れたら1が出力されるのは確認した?

402:デフォルトの名無しさん
09/10/16 12:49:08
正確じゃないのは仕方ないよ

403:デフォルトの名無しさん
09/10/16 13:27:30
何を入力して何を期待して何が出力されたのかくらい書けよ

404:デフォルトの名無しさん
09/10/16 13:35:48
>>396
Cだとそれができないというのは変な話だな

405:デフォルトの名無しさん
09/10/16 13:46:09
炊飯器のボタンの上にアームをつけてそれを制御すればいいじゃん

例のジョークRFCを実装したコーヒーポットとかそんな感じだろ

406:デフォルトの名無しさん
09/10/16 13:51:24
ぐぐったら 本当に実装してるのなw

RFC URLリンク(www.studyinghttp.net)
実装 URLリンク(alpha.mixi.co.jp)

407:デフォルトの名無しさん
09/10/16 13:56:43
良く読むと HTCPCP準拠の実装じゃなかった

408:デフォルトの名無しさん
09/10/16 14:17:42
◆宣伝、広告◆
腕に自信のあるプログラマは、以下のコンピュータ大富豪大会に参加しましょう。

ひろゆき杯コンピュータ大富豪大会
URLリンク(uecda.nishino-lab.jp)


○What's UECda?

大貧民(または大富豪)は、我が国で最もポピュラーなトランプ・ゲームのひとつでしょう。
このゲームは、1960年頃に日本で生まれたと言われており、海外では、ほとんどプレイされていないようです。
本大会は、その日本固有の人気トランプ・ゲームである大貧民を、人が直接プレイするのではなく、
プレイするコンピュータ・プログラムを作成して持ち寄り、対戦させる大会です。

主催

電気通信大学

409:デフォルトの名無しさん
09/10/16 14:37:38
でたらめ言うな
中国でも有名なゲームだ

410:デフォルトの名無しさん
09/10/16 16:27:54
ふつう海外に中国は入らない

411:デフォルトの名無しさん
09/10/16 16:57:48
>>401
したよ
πいれても1になっちゃったけどね
ほかにもπ/3なんかも1になる

412:デフォルトの名無しさん
09/10/16 17:03:19
πを3.14・・・にしたらなんかできました
なんでπだとだめだったんだろう

413:デフォルトの名無しさん
09/10/16 17:05:22
( ゚д゚)ポカーン

414:デフォルトの名無しさん
09/10/16 17:30:33
なるほど、数値入力の場面で「π」を入力したのか。
んで、たまたまaの初期値が0だったから1になったんだな。
当然、「π/3」を入れても同じ結果なわけだ。

415:デフォルトの名無しさん
09/10/16 18:28:32
PIと入れればよかったのに

416:デフォルトの名無しさん
09/10/16 18:29:26
scanfが数式を勝手に変換してくれると思ってたのか

417:デフォルトの名無しさん
09/10/16 18:35:22
>>415
お前はなにを言ってるんだ

418:デフォルトの名無しさん
09/10/16 18:40:26
まあ言いたいことは分かるけどね…

419:デフォルトの名無しさん
09/10/16 19:46:51
>>414
クソワロタ

420:デフォルトの名無しさん
09/10/16 20:42:20
int i = 3;
このとき
i=i+1;やi++;や++i ;
の意味は分かっていますが、
i = i++;
は未定義の動作になるのですね。
i = ++i;
はどうでしょうか?
これも未定義の動作になりますか?



421:デフォルトの名無しさん
09/10/16 20:54:13
未定義です。

422:デフォルトの名無しさん
09/10/17 00:03:50
ポインタを勉強中なんですが、voidポインタに一度格納したlong値を
表示するにはどうやれば良いのでしょうか。
下記例ではコンパイルが通りません。

long a = 10;
void *p = &a;
printf("%f", *p);

423:デフォルトの名無しさん
09/10/17 00:05:29
ポインタを勉強中です。
voidポインタに格納したlong値を表示するにはどうやれば良いのでしょうか。
次の実装ではエラーが起きてしまいます。

long a = 3.14;
void *p = &a;

printf("%f", *p);


424:デフォルトの名無しさん
09/10/17 00:11:46
>>423
printf("%ld", *((long*)p));


425:デフォルトの名無しさん
09/10/17 00:20:25
なんだか、2ちゃんねるがおかしい。
重くてやってらんね。
もう寝る...

426:デフォルトの名無しさん
09/10/17 01:00:54
重くないのだが・・・

427:デフォルトの名無しさん
09/10/17 01:02:45
>>426
>>425
韓国から攻撃

428:327
09/10/17 01:04:39
レス下さった皆様ありがとうございました.
いつもこのスレにはお世話になってます.m(_ _)m

429:デフォルトの名無しさん
09/10/17 01:07:18
重いよ

430:デフォルトの名無しさん
09/10/17 01:08:34
>>410
でたらめ言うなゴミ


431:デフォルトの名無しさん
09/10/17 01:22:06
>>424
ありがとうございました!

432:デフォルトの名無しさん
09/10/17 02:19:28
どういたしまして

433:デフォルトの名無しさん
09/10/17 03:23:07
(´・ω・`)←さっきポイ捨てされたこれを踏んだ。祝日。

434:デフォルトの名無しさん
09/10/17 03:34:24
今から学ぶとしたらC/C++/Javaどれが一番最初がいい?

435:デフォルトの名無しさん
09/10/17 05:58:02
次に書き込んだときの秒数が1〜3ならC、4〜6ならC++、7〜9ならJava、0なら全部

436:デフォルトの名無しさん
09/10/17 08:44:03
最初はインタプリタの方がなじみやすいと思う


437:デフォルトの名無しさん
09/10/17 08:47:36
Cだったな

438:デフォルトの名無しさん
09/10/17 09:14:04
これか
URLリンク(root.cern.ch)

439:デフォルトの名無しさん
09/10/17 12:20:59
short x;


x = (x+0x4000) >> 15;

このコードの意味を教えてください

440:デフォルトの名無しさん
09/10/17 12:27:49
>>439
if(x+0x4000>=0) x=0;
else x=-1;

441:デフォルトの名無しさん
09/10/17 12:42:07
xたす0掛ける4000が15より十分大きいかどうかの真偽値をxに代入

442:デフォルトの名無しさん
09/10/17 12:44:39
>>はビットシフトで切り捨ての処理だと思うんですが,0x4000 を加算する理由がわかりません

443:デフォルトの名無しさん
09/10/17 12:49:10
実装依存だからこのコードに確かな意味は無いよ

444:デフォルトの名無しさん
09/10/17 12:50:38
>>442
上位1ビットが整数部、下位15ビットが小数部の固定少数で、
四捨五入してんじゃね?

445:デフォルトの名無しさん
09/10/17 13:14:09
classのprivateにしたら、そのクラス以外アクセスできないと聞いていたが
ポインタでメンバーにアクセスできんぞ、いいのかこれ

446:デフォルトの名無しさん
09/10/17 13:18:32
設計上良いか悪いかはあるけど、仕様の上では問題ない

447:デフォルトの名無しさん
09/10/17 13:18:41
>>445
なんか無理やりなことをしないとアクセスできないだろ?
それにここ、Cのスレだし。

448:デフォルトの名無しさん
09/10/17 13:27:48
ぐぐってみたらコンパイル前にしかprivate,publicは影響しないんだな

449:447
09/10/17 13:32:07
よく考えたら、無理やりじゃなくても、メンバ変数のポインタを外にだすメンバ関数があればそうなるのか。

メンバ変数のナマのハンドルやら外にだすなってのは、オブジェクト指向のお作法本によく書いてあるな。

450:デフォルトの名無しさん
09/10/17 14:00:00
>>439
int main(void)
{
short x;
short y;
for(x=-32768;x<=32767;x++)
{
y=(x+0x4000)>>15;
printf("x=%d y=%d\n",x,y);
}
return 0;
}

451:デフォルトの名無しさん
09/10/17 14:03:37
double型の変数にビットシフトはできないですか?

値を2倍、4倍,8倍としたいんですが

452:デフォルトの名無しさん
09/10/17 14:26:32
円周率を出力するプログラムpi.exeがあったとして、これを一度pi.datに出力して

double pi =
#include "pi.dat"
;

とすればpiには円周率が入りますが、一度ファイルに出力をせずにそのままほかのプログラムの出力結果をincludeするといったことはできないでしょうか?

453:デフォルトの名無しさん
09/10/17 14:27:56
指数部があるからね

454:デフォルトの名無しさん
09/10/17 14:34:55
>>452
doubleに入れるくらいの桁数なら、ソースに直書きでいいんじゃね?

455:デフォルトの名無しさん
09/10/17 14:36:22
円周率ってmath.hで定義されてなかったけ

456:452
09/10/17 14:38:24
>>454
すいません円周率は例で、ファイル経由せずにプログラムの出力をincludeする方法が知りたいんです

457:デフォルトの名無しさん
09/10/17 14:38:44
# define M_PI           3.14159265358979323846  /* pi */

458:デフォルトの名無しさん
09/10/17 14:41:34
>>456
sedとか使って、置換すれば

459:お願い!
09/10/17 14:44:02
URLリンク(ha.ckers.org)

このスクリプトをC言語で書き直してください

460:デフォルトの名無しさん
09/10/17 15:01:06
こんにちは。どなたかC♯でBMI計算プログラムをvisual studio 2008 もしくは2005 で作成してアップしてくださいませんか・・・?
そのプロジェクトフォルダ全部をアップお願いします。

461:デフォルトの名無しさん
09/10/17 15:08:27
いつからここは丸投げスレになったんだ?

462:デフォルトの名無しさん
09/10/17 15:10:14
マルチしてるバカがいるんだよ

463:デフォルトの名無しさん
09/10/17 15:19:59
>>456
昔のIOCCCのエントリにこんなのがあった
URLリンク(www0.us.ioccc.org)

同様に、ネームドパイプをうまく使えばできるんじゃないかね

464:デフォルトの名無しさん
09/10/17 16:20:10
#include "/dev/tty○○"
とかしたら

465:デフォルトの名無しさん
09/10/17 16:28:09
何となく書いたら1レス前に既出だった……

466:デフォルトの名無しさん
09/10/17 17:29:57
const float *const hoge;


これはどういったポインタなんでしょうか?;

467:デフォルトの名無しさん
09/10/17 17:31:54
>>451
*2, *4, *8でおk。

468:デフォルトの名無しさん
09/10/17 18:23:44
>>466

const float *hoge;
*hoge = 1.0; //エラー
hoge = NULL; //OK

float const *hoge;
同上

float * const hoge;
*hoge = 1.0; //OK
hoge = NULL; //エラー

469:デフォルトの名無しさん
09/10/17 18:32:38
>>468

ポインタがさす実体は変えれない。
さすところは変えれます

const float *hoge;
*hoge = 1.0; //エラー
hoge = NULL; //OK



float const *hoge;
同上


float * const hoge;
*hoge = 1.0; //OK
hoge = NULL; //エラー

よくわかりません。 *がどこに関連するのかが見えません

470:デフォルトの名無しさん
09/10/17 18:39:53
基数ソートの勉強をしています。

16ビット長の値(unsigned short)を4ビットずつ分割して、その分布を調べて
ソートする、というアルゴリズムらしいのですが、ちょっとわからない点があります。

2^4 = 16 ですから、分布を数えるために使う配列は int count[16] と宣言しました。
16ビット長の値を4ビットずつ分割して(分割された値を A とします)、その分布を調べるわけですが、
教科書にあるコードは

count[A & 0x0f]++;

となっています。
ここで、A & 0x0f するのはどうしてでしょうか?
A は4ビット長なわけですから、大きさ16の配列 count に収まるはずです。

なぜ、わざわざ 0x0f との論理積を求めるのか謎です。
よろしくお願いします。


471:デフォルトの名無しさん
09/10/17 18:41:34
じゃあ
float other = -1.0;
const float *hoge1 = &other;
float const *hoge2 = &other;
float * const hoge3 = &other;
const float * const hoge4 = &other;
のように直してそれぞれコンパイルしてみろ。

472:デフォルトの名無しさん
09/10/17 18:41:36
>>466
float型のconst変数を指すポインタ型のconst変数

float a; // float型の変数
const float b; // float型のconst変数
const float *c; // float型のconst変数を指すポインタ型の変数
const float *const d; // float型のconst変数を指すポインタ型のconst変数

473:デフォルトの名無しさん
09/10/17 18:43:49
>>470
unsignedで4bitに収まる保証があるなら論理積とらなくてもいいよ

474:デフォルトの名無しさん
09/10/17 18:49:37
>>470
それだけじゃ分からん。Aの時点ではまだ4bitに分割しきれてないとか。

475:デフォルトの名無しさん
09/10/17 18:50:39
>>473
あ、すみません。。
ソース読み直してみたら、僕が勘違いしていますた。

忘れてください。

476:デフォルトの名無しさん
09/10/17 21:37:57
低水準ファイル入出力を使うメリットを教えてください

477:デフォルトの名無しさん
09/10/17 21:39:11
>>476
それを聞くような人にとってはメリットはありません

478:デフォルトの名無しさん
09/10/18 03:40:33
C言語始めたばかりでまだifとforぐらいしか使えません
2で割れる数、5で割れる数、2と5で割れる数を1000個目まで出力したいのですがうまくカウントできません

for ( k = 1 ,count =1 ; count <= 1000 ; k++, count=count+1) {
if( k%5==0 && k%2==0){
printf("%dは5,2で割り切れます。%d回目 \n" , k,count) ;
}else if(k%2==0){
printf("%dは2で割り切れます。 %d回目 \n" , k ,count) ;
}else if(k%5==0){
printf("%dは5で割り切れます。 %d回目 \n" , k,count ) ;
} }

こんな感じで書いたのですがどこが悪いんでしょうか?

479:デフォルトの名無しさん
09/10/18 03:45:05
別に悪くないよ?

480:デフォルトの名無しさん
09/10/18 04:14:04
for ( k = 1 ,count =1 ; count <= 1000 ; k++) {
if( k%5==0 && k%2==0){
printf("%dは5,2で割り切れます。%d回目 \n" , k,count++) ;
}else if(k%2==0){
printf("%dは2で割り切れます。 %d回目 \n" , k ,count++) ;
}else if(k%5==0){
printf("%dは5で割り切れます。 %d回目 \n" , k,count++) ;
} }

よくわからんが、こういうこと?

481:デフォルトの名無しさん
09/10/18 12:18:09
if( k%5==0 && k%2==0){

これはこうも書けるな
if( k%10==0 ){

482:デフォルトの名無しさん
09/10/18 12:26:23

数学厨おつ

483:482
09/10/18 12:27:37
あ、なんでもないっす^^
さーせん w

484:デフォルトの名無しさん
09/10/18 12:32:03
なんでもないことないだろう
そこんとこ詳しく教えてくれないかな

485:デフォルトの名無しさん
09/10/18 12:33:56

a='d'
b='h'

fprintf(file,"abc%c efg%c",a,b);
とすると出力が

abcd
efgh

といった具合に自動で開業されてしまいます。
させな方法はありますか?

abcd efgh
と出力させたい

486:デフォルトの名無しさん
09/10/18 12:34:43
>>480
ありがとうございます
望んでいたような結果が出力されました

ちなみに丁度1000個目だけを出力することってできますか?
if(count==1000)のときだと違う結果が出力されてしまいます。

487:デフォルトの名無しさん
09/10/18 12:44:20
>>485
改行されてるのはどうやって確認したの?
実際に入ってる改行コードは何

488:デフォルトの名無しさん
09/10/18 12:48:45
>>487
windows、VC++でコンパイルしてできた.exeを実行しました。
改行コード \n,\rとかですか?


489:デフォルトの名無しさん
09/10/18 12:58:28
fscanfで読もうとしている、に1000ペリカ

490:デフォルトの名無しさん
09/10/18 13:02:29
fscanfはつかってないのに?ww

491:toya
09/10/18 13:12:59
wikibooksでC言語の教科書を執筆しています。協力者求む。
URLリンク(ja.wikibooks.org)

492:デフォルトの名無しさん
09/10/18 13:13:29
全角スペース。


493:デフォルトの名無しさん
09/10/18 13:14:56
C体験記じゃんw

494:デフォルトの名無しさん
09/10/18 13:29:25
>>488
いやいや、実行してできたファイルをダンプしたりしてみてよ
デバッガは使えないのかな?

495:デフォルトの名無しさん
09/10/18 13:32:34
その実際のコード貼れよ。
その例みたいに全角スペースなのか?


496:デフォルトの名無しさん
09/10/18 13:41:22
>>486
for(k=1,cnt=1; ; k++) if(k%2==0 || k%5==0) if(cnt++ == 1000) break;

printf("%d", k);

497:デフォルトの名無しさん
09/10/18 13:47:32
>>485
別のプロセスで出力ファイルが開かれてたりして、実際には書き込まれてないんじゃないかな。

498:デフォルトの名無しさん
09/10/18 13:56:09
>>496
そのプログラムちょっとミスって
fork(k=1,cnt=1; ; k++) if(k%2==0 || k%5==0) if(cnt++ == 1000) break;
printf("%d", k);
ってやったら大変なことになっちゃったんだけど。
絶対落ちないって有名なLinuxが二度と起動しなくなった。

499:デフォルトの名無しさん
09/10/18 13:58:58
コンパイル通るのか?

500:デフォルトの名無しさん
09/10/18 13:59:53
アホか。
ゾンビプロセスが増えただけで、カーネルは落ちてないだろ。
死ねよマルエツマカ。

501:デフォルトの名無しさん
09/10/18 14:01:28
コンパイルできない

502:デフォルトの名無しさん
09/10/18 14:01:28
>>498
はいはい、面白い面白い。
これで満足?

503:デフォルトの名無しさん
09/10/18 14:14:13
>491
間違っている部分は、直してあげた方がいいのか。

>498
俺様fork()ならたぶんコンパイルできると思うけど、一般的なfork()ではコンパイルできないと思われる。

504:デフォルトの名無しさん
09/10/18 14:26:38
またマルエツマカが荒らしてる

505:485
09/10/18 14:38:59
全角はたまたまみすた
URLリンク(oshiete1.goo.ne.jp)
ぐぐったけどたぶんこういうことだとオモワレ。

それにしても自動改行ってなんだ?・・・

506:485
09/10/18 14:42:58
全角はたまたまミスた
URLリンク(oshiete1.goo.ne.jp)
ググったけどたぶんこういうことだと思われ。

それにしても自動改行ってよくわからん

507:デフォルトの名無しさん
09/10/18 14:54:14
コード貼れっつーの。
勝手に改行なんてしねえよ。
何かミスってるだけだろ。

508:デフォルトの名無しさん
09/10/18 15:13:54
>>506
どうやって改行してることを確認したかってのはまさにそのことが知りたかったのだけど。
使ってるエディタやコントロールが、自動で折り返したんじゃないかと。
だからファイルに出力したらダンプやバイナリエディタで改行コードが入ってるのか調べてみなさいよ、と。

509:デフォルトの名無しさん
09/10/18 17:59:04
Q1:
QUESTION1;        ←ヘッダーにあるdefineで問題呼び出し
fgets (buf, sizeof (buf), stdin);
sscanf (buf, "%d", &ans);

if (1 <= ans && ans <= 3 ){
if (ans == 2){
printf("正解\n");
point++;
}else{
printf("はずれ\n");
}
}else{
printf("1〜3の数字おして。もっかい。\n");
goto Q1;
}

Q2:
ans = 0;
QUESTION2;
以下ループ

3択クイズ形式学習プログラムを作ったのですが、fgets→sscanfのところで数字を入力してEnterを押すと、
次の問題のif文のelseが1度実行される(1〜3を押せエラー→Gotoで問題が2回表示される)のですが、
なぜそうなるのかわからず対処できません。
単純にエンターを1回押してるのに入力を2回(複数回)受け付けてるだけなんでしょうか・・?
もし、そうならどのように対処すればいいのでしょうか。


510:デフォルトの名無しさん
09/10/18 18:14:28
これの前後の部分に問題ありってことだね。
「問題」ってのは question じゃなくて problem な。

511:デフォルトの名無しさん
09/10/18 18:17:07
>>510

?

3択クイズの問題 = question

512:デフォルトの名無しさん
09/10/18 18:28:28
すげえ読解力だな。

513:デフォルトの名無しさん
09/10/18 20:10:08
const char * name[] = {"aaa" , "bbb" , "ccc" , "ddd" , "eee" , "fff"};
このとき、
name
の要素数を取得するにはどうすれば良いでしょうか?


514:513
09/10/18 20:12:38
すみません。
ちょっと撤回します。

失礼しました。



515:デフォルトの名無しさん
09/10/18 20:23:19
>>119
for (cnt = 0; cnt < no; ++cnt) {}の方が見慣れてるって本当?
入門書ってだいたい
for(cnt = 0; cnt < no; cnt++){}ってかいてあるけど

516:デフォルトの名無しさん
09/10/18 20:32:56
>>515
「見慣れてる」ってのは0からカウントするってところだろ。

517:デフォルトの名無しさん
09/10/18 20:47:42
> cnt++

その世代に言わせると整数は i だろ

518:デフォルトの名無しさん
09/10/18 20:54:28
cntならiのほうがいいな。

519:デフォルトの名無しさん
09/10/18 21:06:16
>>515
C++の流儀だな。
cnt++より++cntの方が、オブジェクトを生成しない分高速。

520:デフォルトの名無しさん
09/10/18 21:36:59
>>496
できました
ありがとうございました

521:デフォルトの名無しさん
09/10/18 21:37:46
usage: command.exe 〜みたいなコマンドのヘルプを表示させるとき、決まった構文ルールはあるの?
省略可能なオプションは[]とか、必須オプションは<>とか。

522:デフォルトの名無しさん
09/10/18 21:48:53
正規表現の簡易型みたいな感じだろ。

523:デフォルトの名無しさん
09/10/18 23:24:16
char型の変数の中身を参照するときに文字コードとして扱いたいときは
if(moji[0] == 115)
のような形でいいんでしょうか?

524:デフォルトの名無しさん
09/10/18 23:28:04
はい
ただし char は符号付きの場合があるので 128 以上の値の扱いに気をつけて

525:デフォルトの名無しさん
09/10/19 02:08:01
stdinの中身を確認する方法ないですか?
空かどうかわかるだけでもいいです。

526:デフォルトの名無しさん
09/10/19 02:19:08
>>525
環境依存しない方法は無い

527:デフォルトの名無しさん
09/10/19 02:19:32
空とはどういう状態か?

528:デフォルトの名無しさん
09/10/19 02:25:11
feof() 辺りかな?
つーか、これを使う機会って無いよな。

529:デフォルトの名無しさん
09/10/19 02:27:10
ああ、もしかして stdin の接続先のことなのかな?
質問が曖昧で難しいな。


530:デフォルトの名無しさん
09/10/19 02:29:10
エスパーに期待してるんだよ

531:デフォルトの名無しさん
09/10/19 02:37:59
「中身」ってなんだよ?
普通に getchar() で読めば良いだろ。


532:デフォルトの名無しさん
09/10/19 03:21:48
エスパーすると、kbhit

533:デフォルトの名無しさん
09/10/19 03:33:50
入力した数字が素数かどうか判別するプログラム作ったんだけど2と3が判別できない
どこが違ってる?

for(b = 2 ; b<=a/2 ; b=b+1){
if(a%b == 0){
printf("%dは素数ではありません。" ,a);
break;
} else {
printf("%dは素数です。" ,a);
break;
}
}

534:デフォルトの名無しさん
09/10/19 03:45:08
判別の基準が間違ってる。

535:デフォルトの名無しさん
09/10/19 03:50:45
4とか5なら判別できるのか?それ


536:デフォルトの名無しさん
09/10/19 03:53:19
9とか15とか

537:デフォルトの名無しさん
09/10/19 04:16:55
b = 2 ; b<=a/2

ってaが2や3の時はね

538:デフォルトの名無しさん
09/10/19 04:43:11
ループの意味がないw

539:デフォルトの名無しさん
09/10/19 06:47:26
||って一つ目左が真なら右の判定を行うってこと?
偽なら右判定はしないのか?

540:デフォルトの名無しさん
09/10/19 06:56:31
||は左が真の時点で右の判定を行わない。
&&は左が偽なら右の判定を行わない。

541:デフォルトの名無しさん
09/10/19 07:24:30
ありがとう

542:525
09/10/19 07:49:18
void sgets(char *buf,int n)
{
int i;
char c;
for(i=0;i<n;i++){
c=getchar();
if(c=='\n'){
break;
}
buf[i]=c;
}
/*入力バッファを空読みする*/
if(i==n){
while(getchar()!='\n');
}
/*文字数が一文字以外は最後に'\n'を加える*/
if(i!=1){
buf[i]=NULL;
}
}
525です。
上の関数を呼び出した後、入力バッファが空読みされたかどうかをmainで確認
する方法を教えてください。

543:デフォルトの名無しさん
09/10/19 08:31:14
>542
ひどいコードだ

544:デフォルトの名無しさん
09/10/19 09:04:39
>>542
空読みする方法は無いと思え。
初心者なら尚更

545:デフォルトの名無しさん
09/10/19 17:00:38
再帰を使わないで処理する方法はありますか?

546:デフォルトの名無しさん
09/10/19 17:04:12
>再帰を使わないで処理する方法はありますか?
再帰を使わないで処理する方法はないと思うのですか?

547:デフォルトの名無しさん
09/10/19 17:15:05
>>542
EOFで確認するとか?

548:デフォルトの名無しさん
09/10/19 17:31:13
総ての再帰は展開できるはずなんだっけか

549:デフォルトの名無しさん
09/10/19 17:35:27
再帰ってなんですか?
まだ勉強をはじめたばかりなのでわかりません。


550:デフォルトの名無しさん
09/10/19 17:41:03
void func()
{
func();
}

↑みたいなのが再帰です

551:デフォルトの名無しさん
09/10/19 18:00:31
数学的帰納法のなかまです

552:デフォルトの名無しさん
09/10/19 18:02:56
>>547
EOFは読もうとしないと意味がない。
従って、入力が空かどうかは「読み出そうとしたときは空だったかどうか」わかるというだけ。

553:デフォルトの名無しさん
09/10/19 20:05:40
箱の中の猫は見ようとしたときだけ生きてるか死んでるかわかるというだけ。

554:デフォルトの名無しさん
09/10/19 20:06:13
うぜえよお前。

555:デフォルトの名無しさん
09/10/19 20:32:04
>>553
え?
見ようとしなければ生きてるか死んでるか分からないが、どっちかだと言っている?

556:デフォルトの名無しさん
09/10/19 21:30:11
箱の中の猫に心拍計を取り付けて、遠隔でモニタすれば箱を開けなくても生死の別は判断可能


557:デフォルトの名無しさん
09/10/19 21:33:23
それは箱に覗き窓が付いてるのと同じこと

558:デフォルトの名無しさん
09/10/19 21:37:54
それが量子的な現象の影響だとしても
確率的だと言うのはマクロスケールでは現実的ないと思うよ

559:デフォルトの名無しさん
09/10/19 21:55:52
>>547
改行まで空読みしてるだけだろ?
なんでEOFが関係あるんだ。

上のほうの「空読みする方法はない」とか、なんか空読みが
別のものと勘違いされる。

560:デフォルトの名無しさん
09/10/19 22:10:25
542にEOFのチェックがないんだけど

561:デフォルトの名無しさん
09/10/19 22:15:03
>>556
心拍計が壊れている可能性がある
心拍計が正常かどうかを確かめる装置を用意してもそれが壊れているかもしれない
以下無限ループ


562:デフォルトの名無しさん
09/10/19 22:25:16
つサーモグラフィー

563:デフォルトの名無しさん
09/10/19 22:29:49
だからそういう話しじゃないが
サーモグラフィーで観測した瞬間に猫の生死状態が確定するというお話。

564:デフォルトの名無しさん
09/10/19 23:25:35
そもそも箱の中に猫が存在しているかどうかや箱の中に猫が入るような空間が本当に存在しているかどうかなんかも観測しなければ未確定。

565:デフォルトの名無しさん
09/10/19 23:35:50
物理板でやれぼけども

566:デフォルトの名無しさん
09/10/19 23:39:09
物理学者とは犬猿の仲だろjk

567:デフォルトの名無しさん
09/10/19 23:42:03
>>565
×ぼけども
○ぼけ

×物理板
○50代板

568:デフォルトの名無しさん
09/10/20 00:30:25
そのジョーク、いまいち面白くない。

569:デフォルトの名無しさん
09/10/20 00:37:05
ぼけは、私が見ているときにしか、そこにいないのか

570:デフォルトの名無しさん
09/10/20 00:47:18
じゃあ人間が箱の中に入れば良いだろ馬鹿が

571:デフォルトの名無しさん
09/10/20 01:49:45
>>559
お前こそ質問者の意図を分かってるか?

要するに、これを訊いてるわけ
URLリンク(www.nurs.or.jp)



572:デフォルトの名無しさん
09/10/20 02:00:05
それを訊いてるんじゃないでしょ?
> 実際に文字を読み込まずに読む文字があるかどうか確かめ
られたかどうかを訊いてるんじゃないの

573:デフォルトの名無しさん
09/10/20 03:35:23
#if defined(DEBUG) | defined(_DEBUG)

#if defined(DEBUG) || defined(_DEBUG)
の違いってわかります?要は|と||なんですが。。。

574:デフォルトの名無しさん
09/10/20 04:16:52
× Apple II
○ Apple ][

575:デフォルトの名無しさん
09/10/20 04:22:40
Xeno091017 正式版
URLリンク(koreawatcher.at.infoseek.co.jp)
・正式版として最初のリリース。
・Jane終了時の挙動のみ091015試作品から変更された。
────────────
予告どおり、正式版をリリースしました。×ボタンのツールチップ
ヒントに関して、真魚のソースを参考にして修正を試みました。
JaneNidaの開発は事実上終了です。2chの仕様変更などで
対応するかもしれません。

576:デフォルトの名無しさん
09/10/20 05:27:19
>>575
スレリンク(tech板)
こいつ、ここでも宣伝していやがる。
こりゃあ通報かな。

577:576
09/10/20 05:28:53
スレリンク(tech板)
ごめんこっちだった。


578:525
09/10/20 07:45:46
525です。
いろいろ回答ありがとうございます。
自分の意図としては>>571で言っている通りで、それをmainで確かめる
方法を探していたんですけど、難しいのであきらめて違う方法を探してみます。
わかりづらい質問ですいませんでした

579:523
09/10/20 12:05:26
>>524
ありがとうございます
unsigned charを使えば問題なさそうでした

トリップ生成プログラムなんかを試しに作ってみたいんですがgccでコンパイルしたところ以下のエラーが出ます
trip.c:36: error: parse error before "salt"
trip.c:79: error: incompatible types in assignment
79行目のエラーに関してはきっと自分がcrypt関数についてよくわかってないだけな気がするんですが、
36行目のエラーの原因がいまいちわかりません
今までこういう構文エラーの原因は大体前の行に;を忘れていたくらいだったのですが・・・
URLリンク(f50.aaa.livedoor.jp)

どうかよろしくお願いします

580:デフォルトの名無しさん
09/10/20 12:09:56
> else(salt[i] == '`')

このような構文は無い
elseに条件式は付かない

581:デフォルトの名無しさん
09/10/20 13:23:33
>>573
|はビット演算のORで||は論理演算のORじゃなかろか

582:デフォルトの名無しさん
09/10/20 13:35:35
][ 表記は10kBASICからだな

583:579
09/10/20 14:01:41
>>580
参考書引っ張ってきて読んだのにこんなミスするなんて・・・
どうもありがとうございました

584:デフォルトの名無しさん
09/10/20 15:18:47
>>581
俺もそう思う。
上は必ず両辺が評価され、下は必ずしも両辺が評価されないという差も出てくるが、
それがこの場合にどう影響するかがわからん

585:デフォルトの名無しさん
09/10/20 15:30:56
事実上、全く同じだね。

586:デフォルトの名無しさん
09/10/20 21:38:46
3項演算子に空文は使えないんですか。そういう場合はif文で冗長にやるしかないんですか
(aaa == bbb) ? flag = true : ; ;

587:デフォルトの名無しさん
09/10/20 21:52:35
>>586
flag = (aaa == bbb) ? true : flag ;

というかそこに代入処理を書くのはif文が冗長だと思える人から見てスマートな記述なの?

588:デフォルトの名無しさん
09/10/20 21:54:45
(aaa == bbb) ? flag = true : 0 ;


589:デフォルトの名無しさん
09/10/20 22:04:25
いまどきのコンパイラなら3項演算子もif文(処理が一行)もかわらない



ってことはないですか?

590:デフォルトの名無しさん
09/10/20 22:12:38
コンパイラの短縮処理は異常

591:デフォルトの名無しさん
09/10/20 22:19:44
>>589
「かわらないから、読みやすいifのほうがいいじゃん」ってこと?

592:デフォルトの名無しさん
09/10/20 22:27:14
短い場合は3項のほうがifより見やすい俺

593:デフォルトの名無しさん
09/10/20 22:32:57
今読んでるOCamlの本は、

if x < 30 then kihonkyu + x * jikyu
      else kihonkyu + x * yugu_jikyu

より

kihonkyu + x * (if x < 30 then jikyu else yugu_jikyu)

のほうを薦めてるな。

594:デフォルトの名無しさん
09/10/20 22:45:51
>>593
そここそ3項演算子だと思うが、その本ではifですか

595:デフォルトの名無しさん
09/10/20 22:48:44
OCamlっていう言語だたのね。
3項演算子が無い言語ってことかな。

596:デフォルトの名無しさん
09/10/20 22:50:59
値を持ってるifと条件演算子は同じだろ。


597:デフォルトの名無しさん
09/10/20 22:52:57
>>593
これ見て「うわifだ、条件演算子がない言語って不便ね」みたいな
感想をもつやつは、たぶん条件演算子も使えてない。

598:デフォルトの名無しさん
09/10/20 22:54:13
そんな感想持ってるやつは今のところいなさそうだが、誰に向けてレスしてんだ?

599:デフォルトの名無しさん
09/10/20 22:59:35
レスじゃないよ。
>>593 を見て、ifと条件演算子の脳内置き換えができないやつを評してる。

600:デフォルトの名無しさん
09/10/20 23:01:20
いるかどうかもわからないヤツを想像してまで叩きたいのかw

601:デフォルトの名無しさん
09/10/20 23:03:53
話がずれてるな。
処理したくない場合、どう書くかについての話だろ?
>>593はななめってる

602:デフォルトの名無しさん
09/10/20 23:05:42
>>594だけ見るとそう思っているかのように見えるけど>>595で理解してるようだしな
>>597は3項演算子に特別な思い入れでもあるのかねぇw

603:デフォルトの名無しさん
09/10/20 23:07:03
こんなマヌケな書き込みしといて、まだバレてないとか、ごまかせるとか思ってるのか。



604:デフォルトの名無しさん
09/10/20 23:09:32
>>601
いやぜんぜんななめじゃないよ。
条件演算子を効率のためにつかってるって思ってるやつに、
そうじゃないって例を示しただけ。

605:デフォルトの名無しさん
09/10/20 23:10:24
>>591-603
誰にレスしてるかくらいはっきりさせろ蛆虫共

606:デフォルトの名無しさん
09/10/20 23:11:23
>>604
>>593の下の方がいい理由を言ってみろ

607:デフォルトの名無しさん
09/10/20 23:13:06
こんな簡単な例じゃどっともかわらねぇよ

608:デフォルトの名無しさん
09/10/20 23:13:08
>>586
使えない。値を返す必要があるから空文があったら困るだろ。
どうしてもってことなら適当な変数でx=xとか入れときゃいいんじゃね?

609:デフォルトの名無しさん
09/10/20 23:17:04
>>586
> (aaa == bbb) ? flag = true : ; ;
つーか、式を返す形で使わなきゃダメだろ。色々と。

610:デフォルトの名無しさん
09/10/20 23:19:33
>>606
みて分かれよ。
プログラミングの基礎って本に載ってるぞ。
サイエンス社2300円。


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

5146日前に更新/215 KB
担当:undef