C/C++の宿題片付けます 128代目at TECH
C/C++の宿題片付けます 128代目 - 暇つぶし2ch511:デフォルトの名無しさん
09/07/03 14:55:39
[1] 授業単元:情報基礎B
[2] 問題文(含コード&リンク):試験の点数10人分をキーボードから入力し、以下の内容を出力するプログラムを作成せよ。
平均点、標準偏差、得点の高い順の点数リスト(出来れば、バブルソート以外のアルゴリズムでお願いします。)
[3] 環境
 [3.1] OS: Turbo Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 7月7日まで
[5] その他の制限:特にありません。よろしくお願いします。

512:デフォルトの名無しさん
09/07/03 15:35:32
>>493
最後の方の問題がよくわからなかったので、途中までだけれど
URLリンク(codepad.org)

『ベクトルv_1,v_2,...,v_nのすべての要素を計算し表示せよ。』まで実装済み
80行あたりまでが汎用の行列演算処理で、それ以降が今回の問題を解いている

513:512
09/07/03 15:39:58
「MltMatrix」って略し方に絶望した そこは「MulMatrix」だろぉぉぉorz
あと、SetMatrixRow関数の呼び出しでコンパイルエラーがでるようならコメントアウトを外してみて
SetMatrixRow(mat, 0, (NUM[]){3}/*&_v0[0]*/); → SetMatrixRow(mat, 0, &_v0[0]);

514:デフォルトの名無しさん
09/07/03 15:45:50
ピタゴラス数が生成されるみたいだね

515:デフォルトの名無しさん
09/07/03 16:07:54
>>511
URLリンク(kansai2channeler.hp.infoseek.co.jp)

516:デフォルトの名無しさん
09/07/03 16:22:29
>>514
この方法(ピタゴラス数を行列で計算する)は面白いな。初めてみた。
ぐぐったら「ピタゴラス行列」とか呼ばれてて、算数の愛好家には有名みたいだ。

517:デフォルトの名無しさん
09/07/03 16:32:04
>>512さん
本当にありがとうございます。とても助かります。
ちょっとコンパイルしてみます。

518:511
09/07/03 16:32:13
>>515

/tmp/cc9mdrSa.o(.text+0x1f2): In function `main':
: undefined reference to `pow'
/tmp/cc9mdrSa.o(.text+0x217): In function `main':
: undefined reference to `sqrt'
collect2: ld はステータス 1 で終了しました


コンパイルしてみたのですが、こんな表示が出ました。
これはどういうことでしょうか?

519:デフォルトの名無しさん
09/07/03 16:35:28
>>518
>>508

520:デフォルトの名無しさん
09/07/03 16:36:58
>518
その二つの関数が無かったよと

コンパイルの最後にmathが提供してる関数をくっつける作業があるんだけど
そのリンクの段階でもなかったよといわれてる

コンパイルで -lm つけないと

521:デフォルトの名無しさん
09/07/03 16:37:29
初歩的なことですが・・・
std::string aa;
aa.size(128);
char bb[128];
aaにbbを指定バイト分コピーするにはどうしたらいいですか?
ちなみにbbには0x00を含むバイナリデータも含んでいます。

522:デフォルトの名無しさん
09/07/03 16:37:53
どこにつけていいかわからないなら
makefileの中晒して

523:デフォルトの名無しさん
09/07/03 16:43:22
>>521
aa.assign(bb, bb + sizeof bb)

524:デフォルトの名無しさん
09/07/03 16:49:36
>>523
できました。ありがとうございます。

525:522
09/07/03 16:50:07
makefileって何ですか??

526:デフォルトの名無しさん
09/07/03 16:55:43
出題がgccである事をいい事にまたC99でソースを書いてるカスがいるな

527:デフォルトの名無しさん
09/07/03 16:59:09
>>525
拡張子無しのmakefileというのがあるんだけど
コンパイルってmakeとかmake rebuildとかコマンドでやてるんでしょ?

528:511
09/07/03 17:02:35
>>527

cc ファイル名.c ってやるとコンパイルできるタイプなんですが・・・・


529:デフォルトの名無しさん
09/07/03 17:10:43
ソースは何で編集してるんだろうww
linuxのコマンドとかそんなのまで説明しないといけないのか?

530:511
09/07/03 17:13:45
kwrite編集して、コンソールでこんぱいるしておます。


531:511
09/07/03 17:15:49
kwriteで編集して、コンソールでこんぱいるしておます。


532:511
09/07/03 17:31:32
>>529

いま言われた通りやってみたらできました!!!

ご迷惑お掛けしました。ありがとうございました!

533:デフォルトの名無しさん
09/07/03 17:56:21
まじ神っす!!

534:デフォルトの名無しさん
09/07/03 19:01:05
[1] 授業単元:情報処理
[2] 問題文(含コード&リンク):
例えば下図に示すように,通行可能なマス目に'0'が,障害物があって通行不能なマス目に'+'が記されている盤がある.
盤の左上をスタート地点,右下をゴール地点として,経路を表示するプログラムを作りなさい.
盤の例
0 0 + 0 +
+ 0 0 0 +
0 + + 0 0
0 0 + 0 0
+ 0 0 0 0

例えばこのようなアルゴリズムが考えられる.

1) 現在位置を表示の後、進行方向に対して,右に進めるなら右に,そうでなければ直進,それもだめなら左に,さらにそれもダメなら後退する.
2) 1を繰り返してゴールに達したらその旨を表示する.ただし,マス目の数分だけ移動してもゴールに達しない場合はその時点で終了する.

入力形式は、

%> ./a.out 00+0+ +000+ 0++00 00+00 +0000

とする.

[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 7/13

お願いします。

535:デフォルトの名無しさん
09/07/03 20:06:23
>>534 右手沿い
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

int main(int argc, char *argv[]){
int width[100]={0}, height, try_count=0, i, j, x=-1, y=0, d, pd=0;
int vx[4]={ 1, 0,-1, 0}, vy[4]={ 0,-1, 0, 1};

if(argc<2) return 1;
height=argc-1;
for(i=0;i<height;i++){
try_count+=(width[i]=strlen(argv[i+1]));
for(j=0;argv[i+1][j];j++) printf("%c ", argv[i+1][j]);
printf("\n");
}
for(i=0;i<try_count;i++){
for(j=0;j<4;j++){
d=(pd+j+3)%4;
if(x+vx[d]<0 || x+vx[d]>=width[y] || y+vy[d]<0 || y+vy[d]>=height) continue;
if(argv[y+vy[d]+1][x+vx[d]]!='0') continue;
x+=vx[d];
y+=vy[d];
pd=d;
break;
}
if(x==width[y]-1 && y==height-1) break;
}
if(i<try_count) printf("\nゴールに達した\n");

return 0;
}

536:デフォルトの名無しさん
09/07/03 20:35:10
[1] 授業単元: C言語演習
[2] 問題文(含コード&リンク): 乱数を使って配列に値を代入するようにせよ。サイズを変化させて時間を計測してみせよ。
サイズが十倍になると計算結果は何倍になるか?
[3] 環境
 [3.1] OS: Windows/vista
 [3.2] コンパイラ名とバージョン: Visual Studio 2008
 [3.3] 言語:C++
[4] 期限: ([2009年07月9日まで]
[5] その他の制限: 乱数はrand()関数、clock()関数を利用する。

537:デフォルトの名無しさん
09/07/03 20:38:01
>>536の参照データっぽいもの
#include<stdio.h>
void soft_swap(int *x,int *y)
{
int temp;
if(*y<*x){temp=*y;
*y=*x;
*x=temp;}}
void sort_array(int a[],int size){
int i,j;
for(j=0;j<size-1;j++){
for(i=0;i<size-1;i++){
soft_swap(&a[i],&a[i+1]);}}}
int main()
{
int a[100],i,size;
printf("数列のサイズを入力してください\n");
scanf("%d",&size);
printf("数列を入力してください\n");
for(i=0;i<size;i++){
scanf("%d",&a[i]);}
printf("\n");
for(i=0;i<size-1;i++){
sort_array(a,size);}
for(i=0;i<size;i++){
printf("%d",a[i]);}
printf("\n");
return(0);

538:デフォルトの名無しさん
09/07/03 21:14:23
[1] 授業単元:プログラミング演習
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:7月8日 17:00
[5] その他の制限:

539:デフォルトの名無しさん
09/07/03 21:56:21
>>538 課題5
始めにファイル名入れる?

540:デフォルトの名無しさん
09/07/03 22:08:20
1] 授業単元: 数値計算プログラミング
[2] 問題文(含コード&リンク): (1)√57を求めよ (2)三乗根の7を求めよ
               (3)f(x)=3x^3+2x^2+5x-15=0の解を求める
[3] 環境
 [3.1] OS: WindowsXP
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語:C++
[4] 期限: ([2009年07月10日まで]
[5] その他の制限:ニュートン法を用いる 初期値 x0=1

541:デフォルトの名無しさん
09/07/03 22:24:47
>>536
URLリンク(kansai2channeler.hp.infoseek.co.jp)

こんなくだらない内容だと解釈したけど本当に合ってるのだろうか・・・。

542: ◆/91kCCQXBo
09/07/03 22:43:48
>>538 課題4 % gcc -o score score.c
URLリンク(jbbs.livedoor.jp)
>>538 課題5 % gcc -o score2 score2.c
URLリンク(jbbs.livedoor.jp)

543:デフォルトの名無しさん
09/07/03 23:07:12
>>540
// ニュートン法で「f(x) = 0」を解く
#include <iostream>
// f(x) および f'(x)
double f1(double x) { return x*x - 57; }
double f1d(double x) { return 2*x; }
double f2(double x) { return x*x*x - 7; }
double f2d(double x) { return 3*x*x;}
double f3(double x) { return 3*x*x*x + 2*x*x + 5*x - 15; }
double f3d(double x) { return 9*x*x + 4*x + 5; }
int main() {
int n; double x; // 繰り返し回数、初期値
n = 10; x = 1.0;
while (n--) { x -= f1(x) / f1d(x); }
std::cout << "(1) " << x << std::endl;
n = 10; x = 1.0;
while (n--) { x -= f2(x) / f2d(x); }
std::cout << "(2) " << x << std::endl;
n = 10; x = 1.0;
while (n--) { x -= f3(x) / f3d(x); }
std::cout << "(3) " << x << std::endl;
return 0;
}

544:デフォルトの名無しさん
09/07/03 23:50:03
いきなりですいません!!
コンパイラしてくれるサイトってありませんでしたっけ??
以前使ったんですけど忘れてしまって...CやらC++やら選択できてコンパイルしたいデータ貼っつけてって感じのダウンロードいらずのサイトなんですけど。。;;
ネットで調べているんですが出てこなくて。
場違いなのはわかっていますが
ここの人なら知ってると思いまして。。
本当すいません

545:デフォルトの名無しさん
09/07/03 23:52:49
>>544
codepad でググるとか

546:デフォルトの名無しさん
09/07/04 00:07:07
そう!それです!codepadでした!!
早くも返答ありがとうございます!
なんかスッキリしましたw
これでレポートだせそうです。
ありがとうございます!

547:デフォルトの名無しさん
09/07/04 00:38:41
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):
下に示すように,非負の整数値を読み込んで,その数を逆順に表示するプログラムを作成せよ。
なお,負の値を読み込んだ場合は,再入力を促すメッセージを表示すること。

非負の整数を入力してください: 1963
1963 を逆から読むと3691 です.
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン:Visual Studio 2008
 [3.3] 言語: C
[4] 期限: 09年07月04日
[5] その他の制限:なし。

548:547
09/07/04 00:41:31
[4] 期限: 09年07月06日
でした^^;

549:デフォルトの名無しさん
09/07/04 01:01:56
[1] 授業単元: プログラミング
[2] 問題文
二つの整数をキーボードから入力して、ユークリッドの互除法を用いて最大公約数を求めよ。
ただし、関数の再帰呼び出しを用いること。
[3.1] OS Windows
[3.2]VisualC++
[3.3] 言語 C++
[4] 期限:7月6日


わかる方どうかよろしくお願いします。

550:デフォルトの名無しさん
09/07/04 01:13:10
>>547
#include <stdio.h>
int main(void) {
int input;
do {
printf("非負の整数を入力してください: ");
scanf("%d",&input);
} while(input < 0);
printf("%dを逆から読むと",input);
do {
printf("%d",input % 10);
input /= 10;
} while(0 < input);
printf("です");
return 0;
}


551:デフォルトの名無しさん
09/07/04 01:13:59
>>549
#include <iostream>

int gcd(int a, int b)
{
int r = a % b;
if(r==0) return b;
return gcd(b, r);
}

int main()
{
int a, b;

std::cin >> a >> b;

std::cout << gcd(a,b);
}

552:デフォルトの名無しさん
09/07/04 01:19:19
[1] 授業単元:情報処理
[2] 問題文(含コード&リンク):
(1)
URLリンク(kansai2channeler.hp.infoseek.co.jp)
(2)
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: XP
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語:C
[4] 期限: 3日後まで
[5] その他の制限: 構造体
よろしくお願いします。



553:デフォルトの名無しさん
09/07/04 01:22:20
>>547
URLリンク(kansai2channeler.hp.infoseek.co.jp)
無駄に1023桁までの非負の整数値で遊べるようにしてみた。

554:デフォルトの名無しさん
09/07/04 01:26:10
表示するだけなのに、いちいち逆順の文字列を作るのは無駄。

555:デフォルトの名無しさん
09/07/04 01:33:16
それ以前に
>*(reverse + length - i - 1) += *(str + i);
これはねーよw

556:デフォルトの名無しさん
09/07/04 01:33:28
>>554
つい、後でこれを他にも使いまわすように拡張するかもしれんとか考えちゃう人でごめんね。

557:デフォルトの名無しさん
09/07/04 01:35:48
>>555
じゃぁどう書けばいいと思う?

558:デフォルトの名無しさん
09/07/04 01:36:55
こんな題意も満たしてない糞コード、他に使いまわすとか正気かよw

559:デフォルトの名無しさん
09/07/04 01:42:07
[1] 授業単元:アルゴリズム
[2] 問題文(含コード&リンク):url.txtに書き込まれている"http://~をhttp://~に書き換えresult.txtに出力せよ
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 2009年07月05日19:00まで
[5] その他の制限: とくになし

よろしくお願いします.

560:デフォルトの名無しさん
09/07/04 01:43:33
>>559
追記です

できればコメントも書いて頂けるとうれしいです.


561:デフォルトの名無しさん
09/07/04 01:46:53
>>557
普通に計算だけでなんとかならねえ?


562:デフォルトの名無しさん
09/07/04 01:54:39
+=じゃなくて=
mallocで確保した領域は0クリアされてるとは限らない。
そこに文字を足すと元の文字とは別になる可能性が高い。

っていうかお前>>346だろ?
似たようなことやっときながら、全然成長してないのな。

563:デフォルトの名無しさん
09/07/04 01:55:21
>>553
mallocの確認と解放してない。
書き捨てPGならいいけど、課題ならやっととかないと講師がうるさい。

fgetsでは常に改行が入るとは限らないからmain文のfor文で暴走の可能性あり。

っていうかstrlenとかstrchr使えばおk


564:デフォルトの名無しさん
09/07/04 01:58:06
>>561
ちょっと頭冷やしてきて改めて見たら、言われた通り糞コードだった。

565:デフォルトの名無しさん
09/07/04 02:07:37
>>552(1)
URLリンク(kansai2channeler.hp.infoseek.co.jp)

566:デフォルトの名無しさん
09/07/04 02:15:34
>>562
そこは普通に書き間違えてる。
本人は=書いたつもり。

>>563
strlen使ってないのはわざとやってる。
fgetsは素で間違えた。

こんなクソコードにツッコミ入れてくれてありがとう。

567:デフォルトの名無しさん
09/07/04 02:40:45
なんとなーく、だけど、
while(input) {
printf("%d", input%10);
input /= 10;
}
を期待した課題だと思う

568:デフォルトの名無しさん
09/07/04 02:41:57
ごめん>>550見てなかった

569:デフォルトの名無しさん
09/07/04 02:54:30
>>552
Complex c_div(Complex s, Complex t)の部分や、sscanfというものが解りません。
もう少し簡単にして頂けないでしょうか?


570:デフォルトの名無しさん
09/07/04 03:17:52
>>569
題意の通りじゃないの?

571:デフォルトの名無しさん
09/07/04 03:18:53
>>565ではないが
sscanfは文字列に対してscanfする関数
c_divは仕様通りだから。。

572:デフォルトの名無しさん
09/07/04 03:25:18
ならsscanf()は使わずに危険なscanf()でも使って書き直そうか

573:デフォルトの名無しさん
09/07/04 03:26:20
つーか誰か(2)やってくれ
だるい
酒飲んでるし

574:デフォルトの名無しさん
09/07/04 03:30:54
>>569
(1)
URLリンク(kansai2channeler.hp.infoseek.co.jp)

(2)は誰か任せた
寝る

575:デフォルトの名無しさん
09/07/04 03:32:50
>>552 (2)ってポインタ使っていいのか?
構造体の実体渡すの?

576:デフォルトの名無しさん
09/07/04 03:36:02
>>574
ありがとうございました。

577:デフォルトの名無しさん
09/07/04 03:40:22
 typedef struct{
  int bunshi, bunbo;
 }bunsu;

bunsu* bunsu_seki(bunsu* A,bunsu* B)
{
  if(A == NULL) return NULL;
  if(B == NULL) return NULL;
  bunsu C;
  C.bunshi = A->bunshi * B->bunshi;
  C.bunbo = A->bunbo * B->bunbo;
  return &c;
}


578:デフォルトの名無しさん
09/07/04 03:42:02
あーーーーーーーーーーーーすまん>>577は無しで

 typedef struct{
  int bunshi, bunbo;
 }bunsu;

bunsu* bunsu_seki(bunsu* A,bunsu* B)
{
  if(A == NULL) return NULL;
  if(B == NULL) return NULL;
  bunsu* C = (bunsu*)malloc(sizeof(bunsu));
  if(C == NULL) return NULL;
  C->bunshi = A->bunshi * B->bunshi;
  C->bunbo = A->bunbo * B->bunbo;
  return C;
}

579:デフォルトの名無しさん
09/07/04 03:42:34
>>569 (2)
bunsu bunsu_seki(bunsu a, bunsu b)
{
a.bunsi *= b.bunsi;
a.bunbo *= b.bunbo;
return a;
}

>>577
だめじゃね?

580:デフォルトの名無しさん
09/07/04 03:45:31
>>578
どんどん話がややこしい方にすすんでるし題意は満たしてないし

581:デフォルトの名無しさん
09/07/04 03:50:55
いかん
ついつい・・>>552の(2)は>>579でいいね
>>577>>578はなしで

582:デフォルトの名無しさん
09/07/04 03:52:17
ポインタで渡す方が処理が速い伝説に惑わされたらいかんよ

583:デフォルトの名無しさん
09/07/04 03:55:52
実際どっちがいいんだろうね
もっとでかい構造体をリストにして扱うことがほとんどなのでついつい

584:デフォルトの名無しさん
09/07/04 03:56:21
>>574
何か消し忘れた#defineが残ってるな
あれは不要だから消しとけ

585:デフォルトの名無しさん
09/07/04 03:57:50
リストにするなら隣のポインタ持たないとダメだからしょうがないけど。
試しにベンチでもやってみたら?
>>578のはちゃんと呼び出し側でfreeしないとメモリどんどん使うから気をつけてね

586:デフォルトの名無しさん
09/07/04 04:25:38
[1] 授業単元:C+
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
OS: vista
コンパイラ名とバージョン: gcc
言語:C
[4] 期限: 一週間
[5] その他の制限:
4題あります。
テストの類題なのでなるべく簡単に題意を満たす解答をお願いします。



587:デフォルトの名無しさん
09/07/04 04:28:35
>>559
URLリンク(kansai2channeler.hp.infoseek.co.jp)

588:デフォルトの名無しさん
09/07/04 05:08:00
>>586
1.
int sum1toN(int n)
{
    int i, s;

    for(i = 1, s = 0; i <= n; i++){
        s += i;
    }
    return s;
}

2.
#include <stdio.h>
#define PAI 3.14159
void circle(double r, double *enshu, double *menseki);
int main(void){
    double r, enshu, menseki;
    printf("半径を入力 >>");
    scanf("%lf", &r);
    circle(r, &enshu, &menseki);
    printf("円周 = %f 面積 = %f\n"
                , enshu, menseki);
    return 0;
}

void circle(double r, double *enshu, double *menseki)
{
    *enshu = 2.0 * PAI * r;
    *menseki = PAI * r * r;
    return;
}

589:デフォルトの名無しさん
09/07/04 05:08:42
>>586 続き
3.
#include <stdio.h>
int main(void)
{
    int a[8] = { 1, 2, 3, 4, 5, 6, 7, 8 }, i;
    for(i = 0; i < 8; i++){
        if(7 - 2 - i >= 0) a[7 - i] = a[7 - 2 - i];
        else a[7 - i] = 0;
    }
    for(i = 0; i < 8; i++)
        printf("a[%d] = %d\n", i, a[i]);
    return 0;
}

4.
#include <stdio.h>

int main(void){
    char ch[81], max;
    int i;
    gets(ch);
    for(i = 0, max = '\0'; ch[i] != '\0'; i++){
        if(ch[i] > max) max = ch[i];
    }
    printf("文字コード最大は%c <%d>\n", max, max);
    return 0;
}

590: ◆/91kCCQXBo
09/07/04 08:06:02
>>547 0123 の逆順 3210
URLリンク(jbbs.livedoor.jp)

591:デフォルトの名無しさん
09/07/04 11:41:47
>>586
(1)
int sum1toN(int n){
return (n + 1)*n/2;
}
オーバーフローしたら知らん。

592:デフォルトの名無しさん
09/07/04 11:58:38
>>591
仕様は満たしているが、出題者の意図に沿ってないような…。

593:デフォルトの名無しさん
09/07/04 12:03:29
>>592
やっぱ模範解答は>>588だよね。
こっちはこんなのもあるよ程度で。

594:デフォルトの名無しさん
09/07/04 12:40:12
>>586
(3)
#include <stdio.h>

#define SHIFT_NUM 2
#define ARRAY_SIZE 8

int main(void){
int a[ARRAY_SIZE] = {1,2,3,4,5,6,7,8}, i, j;

for(i = 0; i < SHIFT_NUM; ++i){
for(j = ARRAY_SIZE - 1; j > 0; a[j] = a[j-1], --j);
a[0] = 0;
}
for(i = 0; i < ARRAY_SIZE; ++i)
printf("a[%d]=%d\n", i, a[i]);

return 0;
}

簡単かどうかと言われるとどうなんだろう。

595:デフォルトの名無しさん
09/07/04 13:34:22
[1] 授業単元: 関係演算子
[2] 問題文(含コード&リンク):
  どんな計算式でもいいが、10で割ると余りが0になる場合だけをprintf文で表示させろ

[3] 環境
 [3.1] OS: (Windows)
 [3.2] コンパイラ名とバージョン: gcc )
 [3.3] 言語: (C/C++/どちらでも可)
[4] 期限: 明後日まで
[5] その他の制限: 制限なし


596:デフォルトの名無しさん
09/07/04 13:53:08
>>595
#include <stdio.h>
int main(void){
int n = 100;
if( n%10 == 0 ){
printf("%dは10の倍数\n");
}
return 0;
}

こういう意味でおk?

597:デフォルトの名無しさん
09/07/04 13:54:51
>>596
訂正:
printf => printf("%dは10の倍数\n", n);

598:デフォルトの名無しさん
09/07/04 14:01:36
どんな計算式の、計算式が重要。n=100か?

599:デフォルトの名無しさん
09/07/04 14:09:58
>>598
どんな10で割ったら余りが0になる数値を特定しろ
特定方法(計算式)はどんなのでも構わない

って意味じゃないの?

600:598
09/07/04 14:15:41
商を用いて、10で割ると余りが0になる場合だけをprintf文で表示させろ <= これが設問じゃないかと
どんな計算式でもいいが商を用いて、10で割ると余りが0になる場合だけをprintf文で表示させろ

601:デフォルトの名無しさん
09/07/04 14:23:18
>>587
ありがとうございます。


602:599
09/07/04 14:28:30
>>600

int n1, n2
n1 = 123; /* 調査対象 */
n2 = n1 / 10;
n2 *= 10;
if(n1 - n2 == 0){
  表示処理
}

こんなん?

603:aka
09/07/04 14:33:17

情報オリンピックの2008年度予選問題3の連鎖のプログラムを教えてください。

URLリンク(www.ioi-jp.org)



604:598
09/07/04 14:33:30
ループすべき。
#include <stdio.h>
int main() {
  int ans;
  
  for(ans=-21;ans<=21;ans++)
    if(!(ans%10)) printf("%d ",ans);
    else printf(".. ");
}

605: ◆/91kCCQXBo
09/07/04 14:58:08
URLリンク(jbbs.livedoor.jp)
>>538 課題1 % gcc -o space space.c
#include <stdio>
>>538 課題2 % gcc -o innpro innpro.c
#include <stdio>
>>538 課題3 % gcc -o janken janken.c
char janken_com(int seed){
  int t;
  srand(seed); //乱数の種(seed)を設定.

  t=rand()%3; //rand()は整数の乱数を返す関数.rand()%3により0から2の乱数を発生させることができる.

  if(t==0) return 'g';
  if(t==1) return 'c';
  return 'p';
}

606:デフォルトの名無しさん
09/07/04 16:03:08
[1] 授業単元:C
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: XP
 [3.2] コンパイラ名とバージョン:Visual Studio 2008
 [3.3] 言語: C
[4] 期限: 7月7日
[5] 番号の場所を書き直すようお願いします。

607:デフォルトの名無しさん
09/07/04 16:07:08
[1] 授業単元:プログラミング言語2
[2] 問題文(含コード&リンク)
簡単なデータベース機能を持つプログラムを作成しなさい.対象となるデータは自分で考えてください.
  (住所録,商品の在庫,図書,ワールドカップの勝敗....)
 以下の要件を示します.

1. ファイルからデータを読み込む機能をつけること.
2. データは4つ以上の項目を保持させること.
 (住所録では、「名前」「住所」「郵便番号」「電話番号」等で4項目以上)
3. 並び替えの機能をつけること.また並び替える項目が指定できること.
4. 各項目についてデータの検索を行う機能をつけること.また,検索条件を組み合わせることができること.
 (住所録なら,「郵便番号」が 399 で始まって,かつ,「電話番号」が 026 で始まる 等)
5. データは半角英数字(英語やローマ字)で扱ってよい
6. データの追加ができること.
7. データの削除ができること.削除は上記の検索と組み合わせることで,ある条件に合致したデータを削除できること.
8. 追加・削除した結果をファイルに保存できること.

[3] 環境
 [3.1] OS: windows
 [3.2] コンパイラ名とバージョン: cygwinのgccです。 バージョンはわかりません。
 [3.3] 言語: C
[4] 期限: 2009年7月13日まで
[5] その他の制限: 双方向リストまで、終わりました。
対象となるデータは住所録でお願いします。
プログラムに説明を付けてくれると、助かります。

よろしくお願いします。

608: ◆/91kCCQXBo
09/07/04 16:33:55
>>595
#include <stdio.h>
int main(int argc, char *argv[]) {
  int i, c;
  FILE *fp;

  if(argc < 2) {
    printf("Usage : %s filename.ext", argv[0]); return 1; }
  if((fp=fopen(argv[1],"r")) == NULL) {
    printf("%s file open error!", argv[1]); return 1; }
  puts("ASCIIコードが10の倍数の時の、ファイル先頭からの位置:");
  for(i=1; (c=getc(fp)) != EOF; i++) { // 結果の値はファイルから読み込む
    if(!(c%10)) printf("%dx%d ", i, c); // 結果の値が、10 で割ると余りが0になる場合だけを表示
//    else if(!(i%10)) printf("x%d ", c); // 繰返しの回数が、10 で割ると余りが0になる場合
//    else printf("."); // その他の場合
  }
  fclose(fp);
}

609:デフォルトの名無しさん
09/07/04 18:07:38
>>603
URLリンク(kansai2channeler.hp.infoseek.co.jp)

610: ◆/91kCCQXBo
09/07/04 18:57:23
>>606 リストを用いて個人データを格納する表を作成。(穴埋め問題)
URLリンク(kansai2channeler.hp.infoseek.co.jp)

611:デフォルトの名無しさん
09/07/04 19:29:17
>>609
これ「落ちた状態」をいちいち作って数えたんだけど
よく考えたらその必要なかった…。無駄無駄無駄ー!

612:デフォルトの名無しさん
09/07/04 19:53:43
未回答文plz

613:デフォルトの名無しさん
09/07/04 20:12:41
>>603
URLリンク(kansai2channeler.hp.infoseek.co.jp)

>>609で作ったやつの修正版

614:デフォルトの名無しさん
09/07/04 20:55:21
>>607
>8. 追加・削除した結果をファイルに保存できること.
これって追加・削除の「履歴」じゃなくて単に「現在のデータ」でいいんだよね?

615:デフォルトの名無しさん
09/07/04 21:21:31
[1] 授業単元: C言語
[2] 問題文  
URLリンク(kansai2channeler.hp.infoseek.co.jp)
これを参考に、100人以内の生徒ID、名前を入力するプログラムを作る
[3] 環境
 [3.1] OS:  Windows
 [3.2] コンパイラ名とバージョン: VisualC++
 [3.3] 言語 C
[4] 期限: 7月6日 
[5] その他の制限 ソースプログラムにある形の関数を使うこと


616:デフォルトの名無しさん
09/07/04 21:34:14
>>615
これでいいのかな

#include<stdio.h>
#include<string.h>
#define SIZE 100



int main(){

    int i;
    student_type students[SIZE];
    for( i = 0; i < SIZE; ++i ){
        read_student( &students[i] );
    }
}


617:デフォルトの名無しさん
09/07/04 22:26:52
>>613
高校生でも分かる簡単なプログラムになりませんかね?
図々しくてごめんなさい…
ぜひお願いします。

618:613
09/07/04 22:37:57
>>617
いや、そう言われても…
この板の住人なら高校生でも>>613は読めると思うが

一般的な高校生レベルってどんなのよ
まあ、どの行がわからんのか言ってみれ

619:デフォルトの名無しさん
09/07/04 22:52:23
ホント無知で申し訳ないっす。。

printf("%s : %d --> %d\n", filename, N, min);

free(array);
fclose(fp);
}

int check_okikata(int *array, int size, int index, int color)
{

らへんがよく分かりません
どういう意味でしょう?


620:デフォルトの名無しさん
09/07/04 23:30:29
>>614
そうです。
項目が削除されたリストと、項目が追加されたリストを出力します。

621:デフォルトの名無しさん
09/07/04 23:35:28
>>619
つまり動的な配列の確保(mallocとfree)がわからないんだな
じゃあ固定配列で書き換えるから

622:デフォルトの名無しさん
09/07/04 23:56:20
>>619
malloc()とfree()を使わないようにした
URLリンク(kansai2channeler.hp.infoseek.co.jp)

623:デフォルトの名無しさん
09/07/05 00:18:10
>>620
えっ?2つのリストが出力されるの!?
追加や削除をして変更された「現在のデータベースのデータ」のリスト1つじゃないの?

624:デフォルトの名無しさん
09/07/05 01:35:36
[1]数値情報解析
[2]ガウス-ザイデル法によりn元1次方程式を解くプログラムを作りなさい。
[3]
[3.1]Windows
[3.2]Visual Studio 2008
[3.3]C
[4]2009年7月15日
[5]ほぼ素人なので、少しでも優しい表現にしていただけるようよろしくお願い致します。
 あと、パワーポイントでこのプログラムのフローチャートを書いていただければありがたいです。

625:デフォルトの名無しさん
09/07/05 02:42:19
>>624 >>162 問題 >>174 >>177 >>183 解答

626:デフォルトの名無しさん
09/07/05 02:57:38
ガウスザイデル法って反復法だからガウス法と違うだろ

627:デフォルトの名無しさん
09/07/05 03:19:53
C++なんですが、
文字変数aの中身が'a'ならば『aが格納されています』と表示させ、'a'でないならば、
『'a'でない文字が格納されています』と表示させるプログラムを作成せよ
誰かお願いします

#include<iostream>
using namespace std;
int main(){


return 0;
}


628:デフォルトの名無しさん
09/07/05 03:21:02
>>627ですが、間違えました。
文字変数aの中身→文字変数mの中身
でした

629:デフォルトの名無しさん
09/07/05 03:22:32
ファイルから読み込みするの?
それともキーボードの入力を待って入力された文字を判断するの?

630:デフォルトの名無しさん
09/07/05 03:26:02
>>627
文字変数mの中身が'a'ならば『aが格納されています』と表示させ、'a'でないならば、
『'a'でない文字が格納されています』と表示させるプログラムを作成せよ
としか書かれてないんですよね。
ただ書き始めと終わりは下の定型文みたいのを使うんですが
#include<iostream>
using namespace std;
int main(){


return 0;
}

631:デフォルトの名無しさん
09/07/05 03:26:46

>>630ですが間違えました

>>627じゃなくて>>629でした

632:デフォルトの名無しさん
09/07/05 03:55:39
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):
下に示すように,非負の整数を次々と読み込んでいき,各値の二乗値の和を表示するプログ
ラムを作成せよ.なお,整数の読み込みは,負の整数を読み込んだ段階で終了するものとし,
その数の二乗値の和は加算しないものとする.

整数を入力してください
整数1 : 3
整数2 : 5
整数3 : -1
二乗値の合計は34 です.
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン:Visual Studio 2008
 [3.3] 言語: C
[4] 期限: 09年07月07日
[5] その他の制限:なし。

633:デフォルトの名無しさん
09/07/05 04:00:22
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):
下に示すように,行数と列数を読み込み,1 行目には1234567890…を列数の個数だけ,2 行
目には2345678901…を列数の個数だけ,…と表示するプログラムを作成せよ.
ファイル提出: 実行ファイル
何行ですか: 7
何列ですか: 12
123456789012
234567890123
345678901234
456789012345
567890123456
678901234567
789012345678
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン:Visual Studio 2008
 [3.3] 言語: C
[4] 期限: 09年07月07日
[5] その他の制限:なし。

634:デフォルトの名無しさん
09/07/05 04:02:16
>>632
#include <stdio.h>

int main(void)
{
int i = 0, sum = 0, n;

while(1) {
printf("整数%d :", ++i);
scanf("%d", &n);
if(n < 0) break;
sum += n * n;
}

printf("二乗値の合計は%d です.\n", sum);

return 0;
}

635:デフォルトの名無しさん
09/07/05 04:06:28
>>633
#include <stdio.h>

int main(void)
{
int i, j, n, m;

printf("何行ですか:");
scanf("%d", &n);
printf("何列ですか:");
scanf("%d", &m);

for(i=1; i<=n; i++) {
for(j=0; j<m; j++) printf("%d", (i+j)%10);
putchar('\n');
}

return 0;
}

636:デフォルトの名無しさん
09/07/05 06:59:52
>>627
#include<iostream>
using namespace std;
int main(){
char m;
if (m == 'a') cout << "『aが格納されています』" << endl;
else cout << "『'a'でない文字が格納されています』" << endl;
return 0;
}


637: ◆/91kCCQXBo
09/07/05 09:01:09
>>627 関数が使えるなら。
#include<iostream>
using namespace std;
namespace {
  int m;
  void sub(void) {
    if (m == 'a') cout << "『aが格納されています』" << endl;
    else cout << "『'a'でない文字が格納されています』" << endl;
  }
}
int main(){
  m='a';
  sub();
  m='x';
  sub();
  return 0;
}

638: ◆/91kCCQXBo
09/07/05 09:47:08
>>627 テンプレートの中だけ書く。>>626 は無しで。
char m = '\a';
int i;
char data[4]={'m', 'a', 'i', 'n'};

for(i=0; i<=sizeof data/sizeof(char); m = data[i++]) {
    if (m == 'a') cout << "『'a'が格納されています』\n";
    else         cout << "『'a'でない文字が格納されています』\n";
}

639:デフォルトの名無しさん
09/07/05 10:42:52
そのループはギャグのつもり?

640:デフォルトの名無しさん
09/07/05 10:51:16
1週間ぐらい前に文字列表示とか、四則演算とか聞いてた人でしょ。
授業は if 文に入ったらしいが、何も分からないから全部聞くと。

641: ◆/91kCCQXBo
09/07/05 12:35:40
>>595 ループか関数のどちらかは使う必要あり。
#include <stdio.h>
void div10(int c) {
  if(c%10) ; else printf("%dは10で割り切れる数\n", c);
}
int main() {
  div10(1);
  div10(20);
  div10(21);
  div10(30);
  div10(13);
  return 0;
}

642:デフォルトの名無しさん
09/07/05 13:10:10
>>638

そのおソースは頂けない
せめてこうしよう

#include <iostream>
using namespace std;

int main()
{
char* data = "main";

for(char* ite = data;*ite != '\0';ite++){
if(*ite == 'a') cout << "aが格納されています" << endl;
else cout << "'a'でない文字が格納されています" << endl;
}

return EXIT_SUCCESS;
}

643: ◆/91kCCQXBo
09/07/05 13:29:31
>>627 どお?
#include <iostream>
using namespace std;
int main(){
  int i = 0;
  char m, data[] = {'m', 'a', 'i', 'n'};

  while( m = data[i], i++ < sizeof data/sizeof(char) ) {
    if (m == 'a') cout << "『'a'が格納されています』\n";
    else         cout << "『'a'でない文字が格納されています』\n";
  }
  return 0;
}

644:デフォルトの名無しさん
09/07/05 13:53:38
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):
モンテカルロ法を用いて、円周率を計算しなさい。なおランダムに打つ点は1000点用いること。
また上記プログラムを改良して、50点打つごとに、真の円周率(ここでは3.1415926とします)
との差を求め、その差をスペースと*を用いてグラフ化しなさい。

[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:7/9
[5] その他の制限:

申し訳ありませんがよろしくお願いします

645:デフォルトの名無しさん
09/07/05 16:52:12
>>644
喜べ、これでキミは英雄だ
URLリンク(kansai2channeler.hp.infoseek.co.jp)

hit-or-missは中心(0,0)半径1の円に入るかどうかで判定した
一様乱数はC標準のものを用いた
おまけとして100000回試行したデータも付けておいた
この判定法と乱数では試行回数が1000回では不十分であると分かるはずだ
改善は他の住人に任せた

646:デフォルトの名無しさん
09/07/05 17:11:25
>>535
遅くなりました
ありがとうございます><

647:デフォルトの名無しさん
09/07/05 17:40:26
>>638
sizeof data/sizeof(char)
>>639が指してるのがこれかどうか分からんけど、とりあえず気持ち悪い

648:デフォルトの名無しさん
09/07/05 17:43:21
>>647
固定配列のサイズを表現する普通の記述だが
なんで気持ち悪いと思う?

649:デフォルトの名無しさん
09/07/05 17:46:18
そっか。
俺ならsizeof(data)/sizeof(data[0])と書くから。
片方にしか括弧つけない意味も分からないし。

650:デフォルトの名無しさん
09/07/05 17:49:14
ああ、そういう意味なら気持ち悪いな
確かに

651:デフォルトの名無しさん
09/07/05 17:51:08
[1] 授業単元:数値計算
[2] 問題文(含コード&リンク):Ax=bの連立1次方程式の解を求めるプログラムを作成しなさい。
   (この行列を使用してください
     A={{10,-9,0,0,0,0,0},
  {-9,17,-8,0,0,0,0},
  {0,-8,17,-9,0,0,0},
{0,0-9,13,-4,0,0},
{0,0,0,-4,12,-8,0},
{0,0,0,0,-8,10,-2},
  {0,0,0,0,0,-2,2}}
b={0,0,0,0,0,0,7})

[3] 環境
 [3.1] OS: Windows Vista
 [3.2] Visual Studio 2008
 [3.3] 言語: C++
[4] 期限: 2009年7月1日まで]
[5] その他の制限:特にありませんがなるべく簡単なものでお願いします
解が{0.37,0.41,1.28,2.06,3.81,4.69,8.19}に近いものになるはずです。




652:デフォルトの名無しさん
09/07/05 17:53:09
>>651
既に期限過ぎてるんだが

653:デフォルトの名無しさん
09/07/05 17:53:15
あとsizeof(char)は常に1だから冗長とかいう奴もよくいるねw
おれは冗長でも書くべきと思う派

654:デフォルトの名無しさん
09/07/05 17:54:36
>>650
どういう意味なら気持ち悪くないの?

655:デフォルトの名無しさん
09/07/05 17:57:09
>>648
読みにくいし i <= sizeof~ だと境界越えてるじゃん
>>642とどっちが読みやすいよ

656:デフォルトの名無しさん
09/07/05 18:00:36
うわあほんとだ。。。
sizeof記述の気持ち悪さに気を取られすぎた俺バカ

657:デフォルトの名無しさん
09/07/05 18:18:03
<<651
私の計算ミスでした。すいません


658:デフォルトの名無しさん
09/07/05 18:55:03
>>651 >>162 問題 >>174 >>177 >>183 解答
何の計算ミス?

659:デフォルトの名無しさん
09/07/05 19:38:56
>>623
返信遅れてすみません。
追加、削除された1つのリストで大丈夫です。

660:デフォルトの名無しさん
09/07/05 20:49:18
[1] 授業単元:情報
[2] 問題文(含コード&リンク):
パソコン甲子園 2008 予選問題 問7 ふしぎな虫
URLリンク(www.pref.fukushima.jp)
[3] 環境
 [3.1] OS: Windows xp
 [3.2] コンパイラ名とバージョン:Visual Studio 2008
 [3.3] 言語: C
[4] 期限: 7月6日

よろしくお願いします。

661:デフォルトの名無しさん
09/07/05 21:34:32
>>645
ありがとうございます。
凄い。誤差ってなかなか安定しないんですね
ですが中身が問題分からなかった低能では
いささか理解が追いつきません
このまま出したら本当に英雄になっちゃいそうです

662: ◆/91kCCQXBo
09/07/05 21:47:10
>>644 差の絶対値をグラフにした。
#include <stdio.h>
#include <stdlib.h>
#define PI 3.1415926
int main() {
  int  i, j, imax = 1000;  /* 乱数の発生回数 1000 */
  int  n, inter = imax/20;  /* グラフの表示インターバル 50 */
  float x,y,pi=PI,eps,mul;
  for(n=0, i=1; i<=imax; i++) {
    /* 0以上1未満の乱数を生成する */
    x = rand()/((float)RAND_MAX+1);
    y = rand()/((float)RAND_MAX+1);
    /* 0<=x,y<=1の範囲にある中心原点半径1の扇形の中に乱数による点が入ったらカウントする */
    if( x*x + y*y < 1) n++;
    if( i%inter ) ; else {    /* 円周率の計算とグラフの表示 */
      pi = (float)n/i*4;    /* 半径1の円の面積すなわち円周率 */
      eps = PI-pi; eps = (eps<0)? -eps : eps;
      if(i==inter) mul = 70/eps; /* 1回目はグラフの倍率を決める */
      printf("%5.3f ", pi);
      for(j=eps*mul; j>=1; j--) putchar(' '); printf("*\n");
    }
  }
  printf("PI=%f\n", pi);
}

663:デフォルトの名無しさん
09/07/05 22:30:36
>>662
ありがとうございます
コメントまで…

何度実行しても値が変わらない気がするのはそういう物ですか?

664: ◆/91kCCQXBo
09/07/05 22:37:17
srand(time(NULL)); を、最初に呼べば毎回変わるはず、>>645のように。

665:デフォルトの名無しさん
09/07/05 22:41:51
>>664
出来ました。が、ときたまグラフが崩れるので封印しときます
勉強になりました

666:デフォルトの名無しさん
09/07/05 23:08:32
>>234で、>>251さんに
URLリンク(kansai2channeler.hp.infoseek.co.jp)
というプログラムを書いて頂いたのですが、RAND_MAXがrand関数の利用に当たるとして
再提出になってしまいました。

rand_maxはrandのとる最大値とのことですが、これを使わないで同様の趣旨を実現するにはどうしたらよいのでしょうか?

667:デフォルトの名無しさん
09/07/05 23:14:25
RAND_MAXをINT_MAXに変える

668:デフォルトの名無しさん
09/07/05 23:53:23
2つの整数をキーボードから入力して、最初の数の方が小さい場合には、『最初の数の方が小さいか等しいです』と表示させて、大きい場合には、『後の数の方が小さいです』と表示させるプログラムを作成せよ

#include<iostream>
using namespace std;
int main(){


return 0;
}


の中に入る文を作るんですが、どうすればいいですか。使うのはifとcoutとelseくらいだと思うんですが


669:デフォルトの名無しさん
09/07/05 23:54:46
>RAND_MAXがrand関数の利用に当たるとして

何ソレ
ただの定数マクロでしょ?

670:デフォルトの名無しさん
09/07/06 00:24:57
>>666
関数の利用に当たる・・・だと・・・
数学科で出された問題?
だったらそのトンチンカンな主張も納得できるけど工学科だったら・・・

671:デフォルトの名無しさん
09/07/06 00:28:29
>>668 例はいらない。
// ↑C++テンプレート
int a1, a2;

cout << "2つの数を入力してください:";
cin >> a1 >> a2;
if(a1<=a2) cout << "最初の数の方が小さいか等しいです\n";
else cout << "後の数の方が小さいです\n";
// ↓C++テンプレート

672:デフォルトの名無しさん
09/07/06 00:49:54
>>671
// ↑C++テンプレート
// ↓C++テンプレート

なんだよ、このコメントは。w
まぁ、>>671の予想通り、minを使うのが速いよってことですね。

673: ◆jmI6IAV7WI
09/07/06 05:28:45
[1] 授業単元: 構造体
[2] 問題文(含コード&リンク): URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語: C
[4] 期限: 7月10日
[5] その他の制限:

よろしくお願いします


674:デフォルトの名無しさん
09/07/06 06:48:27
書くとこ入力部だけじゃねーかw

675: ◆jmI6IAV7WI
09/07/06 07:43:14
>>674
入力部だけでもお願いできないでしょうか
難しくて何がなんだかさっぱりわからないので
すみません

676: ◆/91kCCQXBo
09/07/06 14:11:15
>>673
1.
  printf("1番目のX Y座標をスペースを開けて入力して下さい:");
  scanf("%lf%lf", &my_line.p1.x, &my_line.p1.y);
  printf("2番目のX Y座標をスペースを開けて入力して下さい:");
  scanf("%lf%lf", &my_line.p2.x, &my_line.p2.y);
  printf("2点間の直線距離は:");
2. 三角形の面積 area = fabs(t.p2.x * t.p3.y - t.p3.x * t.p2.y)/2;
  printf("1番目のX Y座標をスペースを開けて入力して下さい:");
  scanf("%lf%lf", &my_triangle.p1.x, &my_triangle.p1.y);
  printf("2番目のX Y座標をスペースを開けて入力して下さい:");
  scanf("%lf%lf", &my_triangle.p2.x, &my_triangle.p2.y);
  printf("3番目のX Y座標をスペースを開けて入力して下さい:");
  scanf("%lf%lf", &my_triangle.p3.x, &my_triangle.p3.y);
  printf("3点で囲まれた三角形の面積は:");

677: ◆/91kCCQXBo
09/07/06 14:25:27
>>624 ガウス・ザイデル法の計算方法 山本昌志 2005年12月16日
URLリンク(akita-nct.jp)

必要なら以下にコメントも付けとく。仮にエクセルのPADでもいい?
#if 0
for( j=1; j<=N; j++ ){
  temp += a[i][j] * x[j];
}
/* a[i][i] * newx + (temp - a[i][i] * x[i]) = b[i]; */
/* a[i][i] * newx = b[i] - (temp - a[i][i] * x[i]); */
newx = 1.0 / a[i][i] * (b[i] - (temp - a[i][i] * x[i]));
#else
for( j=1; j<=N; j++ ){
  if( i==j ) continue;
  temp += a[i][j] * x[j];
}
/* Xi(k+1) = 1/Aii * ( Bi - (Ai,1*X1(k) + Ai,2*X2(k) + ... + Ai,i-1*Xi-1(k) + Ai,i+1*Xi+1 + ... + Ai,n*Xn )) */
newx = (b[i] - temp)/a[i][i];
#endif

678:デフォルトの名無しさん
09/07/06 17:30:17
[1] 授業単元: 情報処理
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)

[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: gcc 3.4
 [3.3] 言語: C/C++
[4] 期限: [2009年7月7日10:00まで]
[5] その他の制限: 特にありません。 

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

679:デフォルトの名無しさん
09/07/06 18:07:23
[1] 授業単元: オペレーティングシステム
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)

[3] 環境
 [3.1] OS: VineLinux4.2
 [3.2] コンパイラ名とバージョン: GCC 4.3
 [3.3] 言語: C/C++
[4] 期限: [2009年7月8日10:00まで]
[5] その他の制限: 特にありません。

C言語なら俺に聞け(入門篇) Part 50
スレリンク(tech板)
>>221で質問しましたが結局分からなかったので
ここに投げさせて頂きました。よろしくお願いします。

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

680:デフォルトの名無しさん
09/07/06 18:25:28
>>493で質問し、一題目を当スレで解答していただいたものです。
その際二題目は問題の意味が解らないということで保留にしていたんですが、
二題目もしなければ駄目ということで再度質問願います。
[1] 授業単元:Cプログラミング入門編
[2] 問題文(含コード&リンク):URLリンク(www-it.sci.waseda.ac.jp)
[3] 環境
 [3.1] OS: UNIX
 [3.2] コンパイラ: gcc
 [3.3] 言語: C

二題目の問題の意味ですが、outputでV1~Vnが表示される度にそれぞれの行列の要素の中で
『V1二乗+V2二乗-V3二乗』を画面Printするという意味と思います。
教授曰くピタゴラスのなにやらと言うらしいのですが、、、。

よろしくお願いします。

681: ◆jvdNOCQgZU
09/07/06 18:31:14
[1] 授業単元:windows開発
[2] 問題文(含コード&リンク): URLリンク(down11.ddo.jp)
[3] 環境
[3.1] OS:Windows
[3.2] コンパイラ名とバージョン:Visual Studio 2008
[3.3] 言語:C++
[4] 期限: [2009年7月9日まで]
[5] その他の制限:DirectX SDK N2008を使用します。
ファイルが大きかったので別のロダ借りました。パス「111」

682:デフォルトの名無しさん
09/07/06 18:49:24
>>680
最初に解答いただいたプログラムです
URLリンク(codepad.org)

よろしくお願いします。

683:デフォルトの名無しさん
09/07/06 19:01:54
>>679
問題 >>前930(9532)>>093(9559)>>172(9532)
このプログラムに、リダイレクション、パイプ機能を実装してください。
>>265(9607)

684:デフォルトの名無しさん
09/07/06 19:23:17
>>679
もう上で答えられてるけど作っちゃったので俺も
URLリンク(kansai2channeler.hp.infoseek.co.jp)

685:デフォルトの名無しさん
09/07/06 19:35:09
>>680
#include <stdio.h>
#include <stdlib.h>
void multiply(int *mat, int *vec, int *out, int N) {
int i, j;
for (i = 0; i < N; i++) {
out[i] = 0;
for (j = 0; j < N; j++) {
out[i] += mat[i*N+j] * vec[j];
}
}
}
int main(void) {
int i, k, N = 3, n = 10;
int *v = (int *)malloc(N * sizeof(int));
int *t = (int *)malloc(N * sizeof(int));
int *P = (int *)malloc(N * N * sizeof(int));
v[0] = 3; v[1] = 4; v[2] = 5;
P[0] = 1; P[1] = -2; P[2] = 2;
P[3] = 2; P[4] = -1; P[5] = 2;
P[6] = 2; P[7] = -2; P[8] = 3;
for (k = 1; k <= n; k++) {
multiply(P, v, t, N);
for (i = 0; i < N; i++) {
v[i] = t[i];
}
printf("v_%d = (%d, %d, %d), ", k, v[0], v[1], v[2]);
printf("v1^2 + v2^2 - v3^2 = %d\n", v[0]*v[0]+v[1]*v[1]-v[2]*v[2]);
}
free(v); free(t); free(P);
return 0;
}

686:デフォルトの名無しさん
09/07/06 20:04:06
>>678
URLリンク(kansai2channeler.hp.infoseek.co.jp)

687:デフォルトの名無しさん
09/07/06 21:00:23
>>685
ありがとうございます。
本当に助かります。
こんなにサッと出来るなんて尊敬します。

688:デフォルトの名無しさん
09/07/06 21:30:15
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):
多数のファイルをクローズせずに何個もオープンするとどうなるか実験せよ.
実験用プログラム fopen.c のソースと実験結果と考察をレポートすること.

% ./fopen
入力ファイル:fopen.c
オープン 1 回目
オープン 2 回目
オープン 3 回目
...
オープン ??? 回目
これ以上オープンできません!

注意:「○○回までオープンできた」とかでは,現象・結果の説明にすぎず,考察とは言えない. その結果から何が理解できるのか?推理せよ. 換言:実験結果(具体例)から一般規則を導き出せ.

[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限:09/07/08
[5] その他の制限: 特になし

689:デフォルトの名無しさん
09/07/06 21:36:20
>>688
追記
その他の制限:ファイル名は決め打ち(ソースファイルなど)でよい.
自分なりに作ったソースは
URLリンク(kansai2channeler.hp.infoseek.co.jp)
考察がわかりません.
セグメンテーションエラーが出るのはわかるのですが…

690:デフォルトの名無しさん
09/07/06 21:47:23
>>689
セゲメンテーションフォルトは fclose(NULL) が悪いだけで考察とは関係ないよ

691:デフォルトの名無しさん
09/07/06 21:55:34
>>690
fclose(NULL)がエラーになる理由を考察に書けばいいと思うんですが、具体的にどう書けばいいのでしょうか


692:デフォルトの名無しさん
09/07/06 21:55:34
>>680
ピタゴラスのなにやらって、三平方の定理じゃねーかw

693:デフォルトの名無しさん
09/07/06 22:11:23
>>691
ストリームをクローズします。

fclose は,引数 stream で指定されたストリームをクローズします。
そのストリームに対応付けられているすべてのバッファは,クローズする前に
フラッシュされます。システムが割り当てたバッファは,クローズすると解放されます。
setbuf または setvbuf を使って割り当てられたバッファは,自動的に解放される
わけではありません(ただし,setvbuf にバッファポインタとして NULL が渡されると,
クローズするときに解放されます)。

とあるから、NULLを無理矢理クローズしようとしてエラーが生じるんじゃない?
規格票には何か書いてあるかな

694:デフォルトの名無しさん
09/07/06 22:16:47
>>691
perror()かなにかでエラー原因表示させてみ

[略)
perror("fopen"); ←ここらへんでperrorを呼んでみる
printf("これ以上オープンできません. \n");
[略)

695:デフォルトの名無しさん
09/07/06 22:23:45
[1] 授業単元:プログラミング入門
[2] 問題文(含コード&リンク):
リスト構造で接続された構造体に含まれる名前を比較し、辞書順にリスト構造の接続を再構成せよ。

[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 2009年07月7日8:00まで
[5] その他:自分で書いたのですが、セグメントエラーになってしまいます。
URLリンク(kansai2channeler.hp.infoseek.co.jp)
なお、これは一番若い名前を見つけたら一旦保持して、最後まで探し終えたら、先頭と保持したものを入れ替えるという動作を
最後までループさせるつもりで書きました。


696:デフォルトの名無しさん
09/07/06 22:36:25
>>693ご教示ありがとうございます.
ファイルをオープンできなかった場合に,そのファイルをクローズしようとするとどうなるかと言う課題もあるのですが,
これも同じ原因でエラーが発生するのでしょうか.
ソースは
URLリンク(kansai2channeler.hp.infoseek.co.jp)
です.

>>694
1回オープンしました.

46回オープンしました.
47回オープンしました.
fopen: Error 0
これ以上オープンできません.

となりました

697:デフォルトの名無しさん
09/07/06 23:01:33
>>684>>685
ありがとうございます。
ちゃんと動作しました。

698:デフォルトの名無しさん
09/07/06 23:06:42
整数2つをキーボードから入力し、(最初にキーボードから入力させる数値を
入れる変数をa、2番目にキーボードから入力させる数値を入れる変数をbとする。)、
最初の数の方が大きい場合には、『最初の数の方が大きいです』、等しい場合には、『両方は等しいです』、2番目の数の方が大きい場合には、『2番目の数の方が大きいです』と表示するプログラムを作成せよ

ある整数変数をキーボードから入力し、その数値が9以下なら『入力した値は1桁です』と表示させて、10以上、99以下の場合は、『入力した値は2桁です』と表示させ、
100以上なら『入力した値は3桁以上です』と表示するプログラムを作成せよ
#include<iostream>
using namespace std;
int main(){

return 0;
}
の中に入る文を作るんです。else とか else if とか ifとか使うはずなんですが誰か教えてくれませんか

699:デフォルトの名無しさん
09/07/06 23:12:55
>>695
ちょっと見ただけだが、
↓これはまずくない?
>struct data* str,str1,str2,tmp,target;

>struct data *str,*str1,*str2,*tmp,*target;

後、動作可能な形で全体をさらす方がアドバイスを受けやすいと思うよ。

700:デフォルトの名無しさん
09/07/06 23:15:40
int first,second;

printf("first: ");
scanf("%d",&first);
if(first>=100)
printf("入力した値は3桁以上\n");
else if(first>=10)
printf("入力した値は2桁以上\n");
else if(first<=9)
printf("入力した値は1桁\n");

printf("second: ");
scanf("%d",&second);
if(second>=100)
printf("入力した値は3桁以上\n");
else if(second>=10)
printf("入力した値は2桁以上\n");
else if(second<=9)
printf("入力した値は1桁\n");

if(first>second)
printf("firstが大きい\n");
else if(first==second)
printf("同じ\n");
else
printf("secondが大きい\n");

701:デフォルトの名無しさん
09/07/06 23:28:11
>>700
あれ?C++なんですけど
coutとかなのですが

702:デフォルトの名無しさん
09/07/06 23:30:28
>>701
C++もCコードかけるからねえ
最初にそういうのは注文で出しておいた方がいいかも

703:デフォルトの名無しさん
09/07/06 23:32:19
using~を見落としてたわ
もう寝るから別の人やって

ところで、テンプレ使えと逆ギレOK?

704:デフォルトの名無しさん
09/07/06 23:45:35
だから、今まで何度もC言語とC++は別言語だからスレッドを分けてくれと言ってきたじゃないか

705:デフォルトの名無しさん
09/07/06 23:54:07
初耳だ

706:デフォルトの名無しさん
09/07/07 00:09:40
[1] 授業単元:C言語
[2] 問題文(含コード&リンク):
URLリンク(www.dotup.org)
[3] 環境
 [3.1] OS:linux
 [3.2] コンパイラ名とバージョン:gcc 3.4
 [3.3] 言語:c
[4] 期限: 7月7日23:59
[5] 特になし

よろしくお願いします

707:デフォルトの名無しさん
09/07/07 00:54:21
>>701
なにがcoutなのですか?
printfはC++じゃないとおっしゃる?

708: ◆/91kCCQXBo
09/07/07 00:56:04
>>698
// ここまではC++テンプレート
cout<<"1番目の整数: ";
cin>>first;
cout<<"2番目の整数: ";
cin>>second;
if(first>second)
  cout<<"最初の数のほうが大きいです"<<endl;
else if(first<second)
  cout<<"2番目の数のほうが大きいです"<<endl;
else
  cout<<"両者は等しいです"<<endl;

cout<<"3番目の整数: ";
cin>>first;
if(first>=100 || first<=-100)
  cout<<"入力した値は3桁以上です"<<endl;
else if(first>=10 || first<=-10)
  cout<<"入力した値は2桁です"<<endl;
else
  cout<<"入力した値は1桁です"<<endl;
// ここからはC++テンプレート

709:デフォルトの名無しさん
09/07/07 01:02:07
>>689
多数のファイルをだからこんな感じじゃないの
うちの環境だとエラーすら出ずに29ファイル目で終わった
コンパイラはbcc,OSはXP SP3
原因はリソース不足?
#include <stdio.h>
#define N 1000
int main(){
int i;
char fname[256];
FILE* in[N];
FILE* out;
for(i = 0;i < N;i++){
sprintf(fname,"hoge%u",i);
out = fopen(fname,"w");
fclose(out);
if((in[i] = fopen(fname,"r")) == NULL){
perror("error");
for(i--;i >= 0;i--){
fclose(in[i]);
}
exit -1;
}
}
for(i = 0;i < N;i++){
fclose(in[i]);
}
return 0;
}

710:512
09/07/07 01:07:49
>>680
>>685で解答済みみたいだけど、一応>>512のコードで求めてみた
URLリンク(codepad.org)
「ElementOf(mat,row,clm)」と「PrintPythagoreanTheorem(int v1, int v2, int v3)」を追加して
main関数に1行追加しただけ
#こっそりMltMatrixをMulMatrixに修正してたりw

711:デフォルトの名無しさん
09/07/07 01:09:23
>>709
1020ファイル作ってsegmentation faultだった。
CentOS5.3(仮想マシン) gcc4.1.2

712:デフォルトの名無しさん
09/07/07 01:11:50
>>711
丁度 out==NULL になったんじゃないかな

713:711
09/07/07 01:12:41
流れをなんにも見てなくてとりあえず動かしただけだったすまん。

>>691
ええと、fclose(NULL)がなぜダメなのかを考察するのはちょっとズレてる
その前にfopenがNULLを返したことに対して考察をすべきよー

714:デフォルトの名無しさん
09/07/07 01:14:45
>>712
大抵out==NULLになって終わるんじゃないかな

715:デフォルトの名無しさん
09/07/07 01:15:34
>>714
in[i]==NULL になることもあるさ

716:711
09/07/07 01:22:12
#include <stdio.h>
#include <stdlib.h>
#define N 10000
int main(){
int i;
char fname[256];
FILE* in[N];
FILE* out;
for(i = 0;i < N;i++){
sprintf(fname,"file/hoge%04u",i);
out = fopen(fname,"w");
if(out == NULL){
perror("error[out]");
for(i--;i >= 0;i--){ fclose(in[i]); }
exit(-1);
}
fclose(out);
if((in[i] = fopen(fname,"r")) == NULL){
perror("error[in]");
for(i--;i >= 0;i--){ fclose(in[i]); }
exit(-1);
}
}
for(i = 0;i < N;i++){ fclose(in[i]); }
return 0;
}

とりあえずちょっと変えてみた。
まあ、他の要因で落ちることを考慮すればin[i]==NULLになることもあるのだろうけれど、
ファイルの開きすぎで落ちるという観点で行けばoutのみじゃない?

717:デフォルトの名無しさん
09/07/07 01:35:43
>>695
いろいろ間違ってる。
nextを使うべきでないところで使っている(このためstr->next・str2->nextでstrやstr2がNULLになることがある)。
最小値がstr1でない場合に、次のループではstr1を跳ばしている(このためstr1がNULLになることがある)。
どうしてもtop入れ換えでやりたいなら、図でも書いて落ち着いて考えること。

top入れ換えではなく、最小値を1個ずつ抜いて別のツリーをつくる方がややこしくなくてお勧め。

struct data *sort(struct data *top){
  struct data work, *d, *target = top, *current = &work;
  for(target = top; target != NULL; target = top){ //元のツリーがなくなるまで
    for(d = target->next; d != NULL; d = d->next){ //最小値探索
      if(strcmp(target->name, d->name) > 0) target = d;
    }
    if(top == target){
      top = target->next; //最小値がtopならtopにnextを保持
    }else{
      for(d = top; d->next != target; d = d->next) ; // 最小値がtop以外なら最小値の親と最小値の子をつなげる
      d->next = target->next;
    }
    current->next = target; // 新しいツリーの末尾に最小値を追加
    current = target;
    current->next = NULL;
  }
  return work.next;
}

718:デフォルトの名無しさん
09/07/07 01:42:03
1] 授業単元:C言語
[2] 問題文(含コード&リンク):n個の整数データを入力し,最後に平均を出力,nは最初に入力する(nは自然数),平均は小数部まで求める実行例として
[3] 環境
 [3.1] OS:Windows
 [3.2] gcc 3.4
 [3.3] 言語:C
[4] 期限:7/7 18時まで
#include<stdio.h>
void main(void)
{
int x,y,z,sum;
double ave;
y=1;
sum=0;
printf("入力するデータ数は? ");
scanf(" %d", &x);
if(x>1){
for(y=1; y=x; y++){
printf("No .%d",y);
y++;
scanf("%d", &z);
sum=sum+z;
}
ave=sum/x;
printf("以上%d個の平均は:%.6f",x,ave);
}
}
とりあえず自分でここまでやってみましたけどわかりません><

719:デフォルトの名無しさん
09/07/07 01:52:24
>>716
横レスだけどファイルを開きすぎて落ちるってどういうこと?
outはきちんとfcloseしてるから再利用してよさそうなんだけどやっちゃダメなの?
後学のためにご教示願います。

720:デフォルトの名無しさん
09/07/07 01:57:27
outはちゃんと閉じてるけどinは増える一方でしょ

0
1 out open
0 out close
1 in open
2 out open
1 out close
2 in open

というながれで、ファイルカウントが最初に最大になるのはoutをopenしたときでしょ

721:デフォルトの名無しさん
09/07/07 02:06:14
なるほどそういうことか。サンクス。

722:デフォルトの名無しさん
09/07/07 02:26:49
>>718
#include<stdio.h>
void main(void)
{
int x,y,z,sum;
double ave;
sum = 0;
printf("入力するデータ数は? ");
scanf("%d", &x);
if(x>=1){
for(y=1; y <= x; y++){
printf("No.%d ",y);
scanf("%d", &z);
sum=sum+z;
}
ave=(double)sum/x;
printf("以上%d個の平均は:%.6f",x,ave);
}
}

723:デフォルトの名無しさん
09/07/07 02:48:35
>>722
ありがとうございます

724: ◆jmI6IAV7WI
09/07/07 05:34:13
>>676
ありがとうございました
助かりました

725:デフォルトの名無しさん
09/07/07 12:44:06
[1] 授業単元: プログラミング
[2] 問題文(含コード&リンク): 整数 nissu をキー入力して、1 月1 日から数えて nissu 日目が何月何日かを表示
したい。 main() 関数を以下のように作った。ここで呼ばれている関数 tuki_hi () を作成せよ。
#include <stdio.h>
int main(){
int nissu, tuki, hi;
void tuki_hi(int, int *, int *);
printf("日数を月日に変換\n");
printf("日数は? "); scanf("%d", &nissu);
tuki_hi(nissu, &tuki, &hi);
printf("%d 日目は%d 月%d 日です", nissu, tuki, hi);
return 0;
}
[3] 環境
[3.1] OS: Windows/vista
[3.2] コンパイラ名とバージョン: borland c++
[3.3] 言語:C
[4] 期限: ([2009年07月7日2:30まで]
[5] よろしくお願いします

726:デフォルトの名無しさん
09/07/07 12:55:20
>>725
void tuki_hi(int nissu, int *tuki, int *hi)
{
int days[13]={0,31,28,31,30,31,30,31,31,30,31,30,31}; /* days[0]は使わない */
int i;
for (i=1; i<=12 && nissu>days[i]; ++i) { nissu -= days[i]; }
*tuki = i;
*hi = nissu;
}

727:デフォルトの名無しさん
09/07/07 14:09:24
>>686 ありがとうございました。

ただ、それぞれの問題につき1つのプログラムという形にしていただけないでしょうか?
自分なりにやってみたんですが、どうも上手くいきませんでした。

お手数ですが、よろしくお願いしますm(_ _)m

728:デフォルトの名無しさん
09/07/07 14:48:07
>>726
ありがとうございましたm(__)m

729:デフォルトの名無しさん
09/07/07 14:56:29
>>727
何も理解できてないな
>>686動かしてみた?

730:デフォルトの名無しさん
09/07/07 16:35:47
>729 すみません… 本当に何も理解しておりません。
>実行結果です。
t23.c: In function `insert_node':
t23.c:130: error: `new' undeclared (first use in this function)
t23.c:130: error: (Each undeclared identifier is reported only once
t23.c:130: error: for each function it appears in.)
t23.c:130: error: parse error before "node_t"
t23.c: In function `remove_node':
t23.c:139: error: `delete' undeclared (first use in this function)
t23.c:139: error: parse error before "del"
t23.c: In function `random_list':
t23.c:149: error: 'for' loop initial declaration used outside C99 mode
t23.c: In function `get_node':
t23.c:155: error: 'for' loop initial declaration used outside C99 mode

731:デフォルトの名無しさん
09/07/07 16:53:30
それ実行じゃなくてビルド時のエラーだろう。
とりあえず C++ でやってみては。

732:デフォルトの名無しさん
09/07/07 17:03:29
[1] 授業単元: プログラミングC
[2] 問題文(含コード&リンク):
キーボードから半角英数で文字列を入力し、英字については大文字を小文字に、小文字を大文字にするプログラムを作成せよ。

実行例 文字列入力 :AbCdEfG123
    変換文字列 :aBcDeFg123
[3] 環境 windows
 [3.1] OS: (Windows/Linux/等々)
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語:C
[4] 期限: 2009/7/9
[5] その他の制限:全くの初心者なのでよろしくお願いします。

733:デフォルトの名無しさん
09/07/07 17:32:46
すいません>>732のものなんですがもう一問あったのでこちらもよろしくお願いします
[1] 授業単元: プログラミングC
[2] 問題文(含コード&リンク):
キーボードから半角英数で文字列を入力し、これを数字(0→9)、大文字(A→Z)、
小文字(a→z)の順に並べ替えるプログラムを作成せよ。
ヒント:並べ替えアルゴリズムは、バブルソート(隣接交換法)を使うと簡単だろう。
    文字列長はstrlen命令を使うとよい。みたいです。
[3] 環境 windows
 [3.1] OS: (Windows/Linux/等々)
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語:C
[4] 期限: 2009/7/9
[5] その他の制限:

734:デフォルトの名無しさん
09/07/07 17:36:08
>>731 提出先のコンパイラーでg++がインストールされてないようです…

cに書き換えるにはどうしたら良いでしょうか?

735:デフォルトの名無しさん
09/07/07 17:37:38
>>730
コンパイルすらできていないのに>>727のコメントが出てくるのがおかしいんだよ。
自分なりに何をやったんだ?って思うんだよなぁ。
てっきりmainがありませんぐらいまではたどり着いてるものだと思っていたが。。

736:デフォルトの名無しさん
09/07/07 17:40:05
>>734
new deleteをmalloc/calloc freeにする
変数の宣言をブロックの先頭で行うようにする

737:デフォルトの名無しさん
09/07/07 17:57:20
Cに書き換えるのも書こうかと思ったんだけど
元々の条件にC/C++って書いてあったからなー

738:デフォルトの名無しさん
09/07/07 18:00:05
>>736 ありがとうございます。

739:デフォルトの名無しさん
09/07/07 18:02:11
>>732
#include <stdio.h>
#include <ctype.h>

int main(void)
{
char str[128];
int i;
scanf("%s", str);
for (i = 0; str[i]; ++i)
if (isupper(str[i])) str[i] = tolower(str[i]);
else if (islower(str[i])) str[i] = toupper(str[i]);
puts(str);
return 0;
}

740:デフォルトの名無しさん
09/07/07 18:31:32
>>733
#include <stdio.h>
#include <string.h>
#include <ctype.h>

int compare(char x, char y)
{
if (isdigit(x)) return isdigit(y)? y - x: 1;
if (isupper(x)) return isdigit(y)? -1: isupper(y)? y - x: 1;
if (islower(x)) return isdigit(y) || isupper(y)? -1: islower(y)? y - x: 1;
return 0;
}
void bsort(char *str)
{
int i, j;
for (i = 0; i < strlen(str) - 1; ++i) {
for (j = 1; j < strlen(str) - i; ++j) {
if (compare(str[j], str[j - 1]) > 0) {
char t; t = str[j]; str[j] = str[j - 1]; str[j - 1] = t;
}
}
}
}
int main(void)
{
char str[128];
scanf("%s", str);
bsort(str);
puts(str);
return 0;
}

741:デフォルトの名無しさん
09/07/07 18:57:59
>>737 そうですね、迂濶でした。
今度こそ自分なりにやってみますが、ダメだったときはお願いしてもよろしいでしょうか…

742:デフォルトの名無しさん
09/07/07 19:02:25
>>734
> 提出先のコンパイラーでg++がインストールされてないようです…
何のエラーメッセージでそう思った? 

とりあえず int main(void){return 0;} の一行を追加して、g++でコンパイルみてはどうだろう。

743:デフォルトの名無しさん
09/07/07 19:52:53
>>742 g++: p11.cpp: No such file or directory
>g++: no input files   です。
>

744:デフォルトの名無しさん
09/07/07 19:56:43
>>743
ばっちりインストールされてるじゃねーかw

745:デフォルトの名無しさん
09/07/07 19:57:03
>>743
which g++
とでもしてろよwwwww

746:デフォルトの名無しさん
09/07/07 19:57:41
↑間違えました。

747:デフォルトの名無しさん
09/07/07 20:01:47
[1] 授業単元:
コンパイラの構成
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: (Windows/Linux/等々)
Windows
 [3.2] コンパイラ名とバージョン: (gcc 3.4 VC 6.0等)
gcc
 [3.3] 言語: (C/C++/どちらでも可 のいずれか)
C(yacc、lex)
[4] 期限: ([yyyy年mm月dd日hh:mmまで] または [無期限] のいずれか)
7月14日
[5] その他の制限: (どこまで習っているか、標準ライブラリは使ってはいけない等々)
前回も>>204で助けていただいたのですが、yaccとlexの問題です。
スレ違いかもしれませんがどなたかよろしくお願いします。

748:デフォルトの名無しさん
09/07/07 20:13:40
>>744 >>745 そうなんですか?W

とりあえず>>686を参考にどうにかしてみます。
どうにもならなかったらまた来させて下さい…

長々とお付き合いありがとうございました!

749:デフォルトの名無しさん
09/07/07 21:07:31

[1] 授業単元:C言語
[2] 問題文:配列を用いた計算機のプログラムを作成してください。
計算は前から順に行われていく。
入力される数値の個数は最大でも20個としてください。

[3] 環境
 [3.1] OS: XP
 [3.2] コンパイラ名とバージョン: Visual Studio 2008
 [3.3] 言語:C言語

[4] 期限:2009年7月12日
[5] その他:特になし
よろしくおねがいします

750:デフォルトの名無しさん
09/07/07 21:09:52
>>706
/*Q1*/
#include <stdio.h>
int main() {
FILE *fp_in, *fp_out; char fname[256], key, buf;
printf("ファイルを暗号化します!\n\n");
printf("入力ファイル名は:"); scanf("%s", fname); fflush(stdin);
if ((fp_in = fopen(fname, "rb")) == NULL) return 1;
printf("出力ファイル名は:"); scanf("%s", fname); fflush(stdin);
if ((fp_out = fopen(fname, "wb")) == NULL) return 1;
printf("暗号化のキー文字は:"); key = fgetc(stdin);
while (fread(&buf, sizeof(char), 1, fp_in) == 1) {
buf = buf ^ key; fwrite(&buf, sizeof(char), 1, fp_out);
}
printf("暗号化が完了しました!\n");
fclose(fp_in); fclose(fp_out);
return 0;
}
/*Q2*/
#include <stdio.h>
void rotate(unsigned char *a) {*a = (*a) << 1 | (*a) >> 7;}
int main() {
int i, k, x; unsigned char a;
printf("1~255の整数を入力 : "); scanf("%d", &x);
a = x;
for (i = 1; i <= 16; i++) {
rotate(&a);
printf("%2d-th shift: %3d ", i, a);
for (k = 7; k >= 0; k--) {printf("%d", (a & (1<<k)) >> k);} printf("\n");
}
return 0;
}

751:デフォルトの名無しさん
09/07/07 21:15:24
>>706
/*Q3*/
#include <stdio.h>
#include <stdlib.h>
void itoa_r(int n, char *str);
enum {MAX = 100};
main() {
int n;
char str[MAX];
while (1) {
int i;
for (i = 0; i < MAX; i++) str[i] = '\0'; // 追加
printf("\n整数を入力して下さい(終了 = 0):");
scanf("%d", &n);
if (n == 0) break;
itoa_r(n, str);
printf("文字列に変換すると %s です\n", str);
}
}
void itoa_r(int n, char *str)
{
if (n < 0) {
*str = '-';
itoa_r(-n, str + 1);
} else if (n != 0) {
int m = n, d = 1;
while (m /= 10) d++;
*(str + d - 1) = '0' + (n % 10);
itoa_r(n / 10, str);
}
}

752:デフォルトの名無しさん
09/07/07 21:58:55
[1] 授業単元:プログラミングC
[2] 問題文(含コード&リンク):


C++言語を使ってスタックを実現するクラスを定義して,その実行を確認するプログラム(main関数)を書く。

クラス名はstackとする。

要素のデータの型はintとする。
格納できる要素の最大数は10とする。
公開されているインターフェースは下記のものとする。

void push(int data);
int pop();

初期設定は,以下のいずれかによって行う。
(1) クラスのコンストラクタ(constructor)の機能を用いる。
(2) 初期設定用のインターフェース(init)を定義し,スタックを使用する前に,initを呼び出す。

機能確認のためのインターフェース(たとえばスタック内のデータを表示させる)を追加してもよい。

上記の仕様を満たさない(インターフェース名が上記と一致しない等)プログラムは評価の対象としない。

#入出力はprintfを用いること。
[3] 環境
 [3.1] OS: Windows XP
 [3.2] コンパイラ名とバージョン: Visual Studio 2008
 [3.3] 言語: C++
[4] 期限: 2009年7月10日まで
よろしくおねがいします

753:デフォルトの名無しさん
09/07/07 22:44:39
>>752
>#入出力はprintfを用いること。
入力もprintfを使わなきゃダメなの?

754:デフォルトの名無しさん
09/07/07 22:54:15
>>752
#include <cstdio>
const int MAX = 10;

class stack {
int *data_;
int n;
public:
stack() { data_ = new int[MAX]; }
~stack() { delete data_; }
void init() { n = 0; }
void push(int data) { if (0 <= n && n < MAX) data_[n++] = data; }
int pop() { if (0 <= n && n < MAX) return data_[n--]; }
void print() { for (int i = 0; i < n; ++i) printf("%d\n", data_[i]); }
};

int main()
{
stack s;
s.init();
s.push(5); s.push(-8); s.push(2); s.print();
s.pop(); s.print();
return 0;
}

755:デフォルトの名無しさん
09/07/07 23:04:34
>>753
とつっこむあなたはprintfで入力ができるんですか?

756:デフォルトの名無しさん
09/07/07 23:25:39
>>752
チェック用の関数と例外処理でcoutを使ってる。
だめそうなら、そこをprintfに書き換えて。

URLリンク(kansai2channeler.hp.infoseek.co.jp)

757:デフォルトの名無しさん
09/07/07 23:28:24
【質問テンプレ】
[1] 授業単元:C言語
[2] 問題文(含コード&リンク): 二次元配列を使って以下のファイルを読み込み、同じように表示しなさい。
 【test.dat】
  ** ** **
  ** ** **
  ** ** **

ポインタを宣言;
データを宣言;
ポインタ=fopen("test.dat",r);

if(ポインタ == NULL) return;

for(i=0; i<3; i++){
for(j=0; j<3; j++){
fscanf(ポインタ,"%d"&sub[i][j]); }}

/* 此処の printf() がどうしてもできません。ご協力お願い致します。 */

fclose(ポインタ);

[3] 環境
 [3.1] Windows
 [3.2] Visual Studio
 [3.3] 言語: C++
[4] 期限:2009年7月8日 09:00まで
[5] その他の制限:特にありませんが、理解したいので比較的簡単なものでお願い致します。

758:デフォルトの名無しさん
09/07/07 23:33:26
>>757
test.datの内容それであってる?整数が3行3列=9個あるんじゃないのか?

759:デフォルトの名無しさん
09/07/07 23:37:20
>>757
"**"は整数なんじゃないかとエスパー

#include <stdio.h>

int main(void)
{
FILE *fp = fopen("test.dat", "r");
int sub[3][3];
int i, j;

if (fp == NULL) return 1;
for (i = 0; i < 3; i++)
for (j = 0; j < 3; j++)
fscanf(fp, "%d", &sub[i][j]);

for (i = 0; i < 3; i++) {
for (j = 0; j < 3; j++)
printf(" %d", sub[i][j]);
printf("\n");
}
fclose(fp);
return 0;
}

760:757
09/07/07 23:39:56
>>758さま

すみません間違えていました;;
指摘していただいて確認したところ、
【test.dat】
** ** **
** ** **
** ** **
** ** **
でした。
そうなると、
for(i=0; i<4; i++){
for(j=0; j<3; j++){
fscanf(ポインタ,"%d"&sub[i][j]); }
}
になると思います・・・すみませんでした><



761:757
09/07/07 23:43:19
>>759さま
あ!そういう意味でしたか・・・すみません、おっしゃるとおりです!
しかも早急にご回答ありがとうございます!!
printf()は普通に書けばよかったんですね・・・なるほど。

>>758さま
>>759さま
お二方、ありがとうございました。

762:デフォルトの名無しさん
09/07/08 00:19:10
[1] 授業単元: 情報処理Ⅰ
[2] 問題文: 乗算合同法で整数乱数を生成.。
区間(0.1)の一様にして、1以上、ある特定の整数の乱数を生成する。
[3] 環境
 [3.1] OS: WindowsXP
 [3.2] コンパイラ名とバージョン: TurboC
[3.3] 言語: C
[4] 期限: 2009年7月20日00:00まで
[5] その他の制限: #include <stdio.h>で始まるようにお願いいたします。

よろしくお願いします。

763:デフォルトの名無しさん
09/07/08 02:15:09
>>624で質問し、>>677で答えていただいた者ですが、
プログラムにコメント文も付けていただけますでしょうか?

764:デフォルトの名無しさん
09/07/08 03:19:26
[1] 授業単元:プログラミング入門
[2] 問題文(含コード&リンク):
問1:フィボナッチ数列を23番目まで計算して配列fibに格納した後、キーボードから何番目かを指定して表示するプログラムを作成せよ。
  要素を表示する処理は何回も繰り返し行えるようにし、キーボードから1~23以外の数値が入力されたら終了する。
  実行例 数の入力:2
        fib[2]:1
        数の入力:23
        fib[23]:28657
        数の入力:24
        終了

問2:(1)キーボードから半角英数で文字列を2つ入力し、これを比較して同じか否かを判定するプログラムを作成せよ。
   実行例 文字列1:ABC               文字列1:ABc
      文字列2:ABC               文字列2:ABC
      2つの文字列は同じです         2つの文字列は違います  
   
(2)(1)のプログラムを、strcmpを使って書き換えなさい。

問3:1週間の売り上げ一覧を表示するプログラムを作成せよ。
   実行例  野菜の1週間の売り上げた合計数量と合計金額 
                                  合計  合計
        種類 単価 月 火 水 木 金 土 日 数量  金額
        レタス 150 50 55 60 65 70 75 80 455  68250
        トマト  50 20 25 30 35 40 45 50 245  12250
        もやし  20 10 15 20 25 30 35 40 175  3500
        ナスビ  40 5  10 15 20 25 30 35 140  5600 
[3] 環境
 [3.1] OS:(Windows
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 2009/7/9
[5] その他の制限: C言語の基本くらいしかやっていません。

765:デフォルトの名無しさん
09/07/08 08:50:32
[1] 授業単元: 数値計算プログラミング
[2] 問題文(含コード&リンク): (1)√57を求めよ (2)三乗根の7を求めよ
               (3)f(x)=3x^3+2x^2+5x-15=0の解を求める
[3] 環境
 [3.1] OS: WindowsXP
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語:C++
[4] 期限: ([2009年07月10日まで]
[5] その他の制限:ニュートン法を用いる 初期値 x0=1
お願いします



766:デフォルトの名無しさん
09/07/08 09:24:58
>>764
問1
#include <stdio.h>

#define N 23

int main()
{
    int fib[N + 1], i, n;

    fib[0] = 0, fib[1] = 1;
    for(i = 2; i <= N; i++)
        fib[i] = fib[i - 2] + fib[i - 1];

    while(1){
        printf("数の入力:");
        scanf("%d", &n);
        if(n < 1 || n > N) break;
        printf("fib[%d]:%d\n", n, fib[n]);
    }
    printf("終了\n");
    return 0;
}

767:デフォルトの名無しさん
09/07/08 09:34:17
>>764
問2
#include <stdio.h>

#define SIZE 1024

int main()
{
    char s1[SIZE], s2[SIZE];
    int i;

    printf("文字列1:"), fgets(s1, SIZE, stdin);
    printf("文字列2:"), fgets(s2, SIZE, stdin);
    for(i = 0; s1[i] != '\0' && s2[i] != '\0' && s1[i] == s2[i]; i++);
    if(s1[i] != s2[i]) printf("2つの文字列は違います\n");
    else printf("2つの文字列は同じです\n");
    return 0;
}

768:デフォルトの名無しさん
09/07/08 09:36:12
>>764
問2(2)
#include <stdio.h>
#include <string.h>

#define SIZE 1024

int main()
{
    char s1[SIZE], s2[SIZE];

    printf("文字列1:"), fgets(s1, SIZE, stdin);
    printf("文字列2:"), fgets(s2, SIZE, stdin);
    if(strcmp(s1, s2) != 0) printf("2つの文字列は違います\n");
    else printf("2つの文字列は同じです\n");
    return 0;
}


769:デフォルトの名無しさん
09/07/08 09:59:42
問3
#include <stdio.h>>

struct weekly_sales_t{
    char kind[1024];
    int price;
    int daily_sales[7];
};

int main()
{
    struct weekly_sales_t sales[4] = {
        {"レタス", 150, {50, 55, 60, 65, 70, 75, 80}},
        {"トマト",  50, {20, 25, 30, 35, 40, 45, 50}},
        {"もやし",  20, {10, 15, 20, 25, 30, 35, 40}},
        {"ナスビ",  40, { 5, 10, 15, 20, 25, 30, 35}},
    };
    return 0;
}

時間ないので誰か任せた

770:デフォルトの名無しさん
09/07/08 10:06:09
>>765
URLリンク(www.geocities.jp)
↑元のソースはここ。
URLリンク(kansai2channeler.hp.infoseek.co.jp)
↑今回の課題に合わせた変更



771:デフォルトの名無しさん
09/07/08 11:11:32
[1] 授業単元:C言語
[2] 問題文(含コード&リンク):下記に
[3] 環境
 [3.1] OS:VistaSP1
 [3.2] コンパイラ名とバージョン: Visual Studio2008
 [3.3] 言語:C
[4] 期限:2009年7月8日23時まで
[5] その他の制限:できるだけ基本で

登録番号"int no"と名前"char *name"と年齢"int age"を含む構造体person型の配列を定義し初期化せよ.
なお, 最後のデータの名前にはNULLを入れておく. 登録番号は入力順に1,2,3,4,5とする.
そして, 登録されている人の平均年齢を計算する関数を作成せよ.
引数は, 配列の先頭アドレスを指す構造体person型のポインタとする.

772:デフォルトの名無しさん
09/07/08 11:57:37
[1] 授業単元: 4次のルンゲ-クッタ法を用いて連立微分方程式を解く
[2] 問題文:システムの状態x = (x, y, z) が、以下の連立微分方程式に従う場合の挙動をシミュレーション
する.
dx/dt= -y - z
dy/dt= x + ay
dz/dt= b + (x - c)z
【課題1】4 次のルンゲ-クッタ法を用いて上記方程式を数値的に解くプログラムreport.c を完
成させよ.report.c には3 つの関数が定義されている.ルンゲ-クッタ法を1 ステップ行う関数
rungekutta() は完成しているが、導関数を求める関数deriv() とプログラム全体を制御する関
数main() は不完全である.各関数に適切な実行文等を記述し、プログラムを実行できるよう完
成させよ.
【課題2】課題1で完成させたプログラムreport.c を用い、シミュレーションを実行する.シス
テムパラメータが
1. (a, b, c) = (1.0, 0.2, 1.0)
2. (a, b, c) = (1.0, 0.2, 8.0)
の2つの場合に、時刻t = 200.0 からt = 400.0 の間にx が位相空間に描く軌跡を図に表せ.シ
ミュレーションの時間刻みはdt = 0.02 とし、初期値x(0) = (x(0), y(0), z(0)) は適当な値を選ぶ
こと.またそれぞれの場合について、初期値をわずかに変化させた場合に軌跡がどのように変化
するかを、同様に図に表して比較せよ.
[3] 環境 Vine Linux
 [3.1] OS:WindowsXP
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語:C
[4] 期限:2009年7月28日
[5] その他の制限:ソースは長いので次レスに投稿します。できれば理解したいのでコメント付きで解説して戴けると助かります。面倒臭い場合は結構です。

どうか宜しくお願いします。


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