C/C++の宿題を片付けます 117代目at TECH
C/C++の宿題を片付けます 117代目 - 暇つぶし2ch446:デフォルトの名無しさん
08/11/09 01:02:30
>>437
ありがとうございます。
>>439
そういう適当な課題なんです

447:デフォルトの名無しさん
08/11/09 02:20:57
440の問題微妙に難しくない?コンパイラ?

448:デフォルトの名無しさん
08/11/09 02:40:51
[1] 授業単元:Cプログラミング
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ名とバージョン:bcc
 [3.3] 言語:C
[4] 期限:11/12
[5] その他の制限:特になし

よろしくお願いします


449:デフォルトの名無しさん
08/11/09 02:52:06
[1] 授業単元:C
[2] 問題文 
 初期設定された任意の整数配列内のデータを,大きい順に並べ換えるプログラム
をつくりなさい。ただし,並べ換える部分を関数にして,配列とデータ数を引数として
渡しなさい。例として,次の10 個の整数を格納した配列に適用してみなさい。
static int dd[10] = { 27, 89, 45, 18, 55, 64, 92, 73, 34, 88 };

出力例:
ソート後 = 92 89 88 73 64 55 45 34 27 18

[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語: C
[4] 期限: 2008年11月10日 24:00
[5] その他の制限:次のようなプロトタイプ宣言をもつ関数isort を定義しなさい。
void isort(int *, int);

できましたら、C言語の基本的な関数のみでお願いします。



450:デフォルトの名無しさん
08/11/09 03:15:08
>>447
関数の名称その他の抽出って感じだろう
構造体を誤認識しないようにしつつ

451:450
08/11/09 03:16:42
ごめんたしかにかなり面倒ですね
どのくらいまでやればいいんだろ

452:デフォルトの名無しさん
08/11/09 03:25:55
>>449
void isort(int * ary, int nelem)
{
int i;

for ( i = 1; i < nelem; ++i ) {
int j;
int tmp = *(ary + i);

for ( j = i - 1; j >= 0 && *(ary + j) < tmp; --j ) {
*(ary + j + 1) = *(ary + j);
}
*(ary + j + 1) = tmp;
}
}
適当に作ってみた。

453:デフォルトの名無しさん
08/11/09 04:05:41
>>448
シンプレックス法だね。でもコードにするのめんどい・・・

454:デフォルトの名無しさん
08/11/09 04:06:41
>>440
途中までやってみた。

・ 基本的に改行を取り除くため1つの char 配列に読み込む
・ // は行単位の処理が必要なので読み込み時に処理
・ /* ~ */ は未対処
・ void, int, char, float, double のいずれかとマッチするところを探す
→ データ型を省略した関数定義は取りこぼす
・マッチしたらそれぞれの直後が ' ' か '\t' か '\n' の条件に絞る
・ '(' が来るまでに ',' か ';' か ')' か '{' か '}' が来たら関数ではない
・以上の条件に合致したら、型名と関数名を出力

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

455:デフォルトの名無しさん
08/11/09 04:16:44
>>452

ありがとうございましt!

456:454
08/11/09 05:20:37
>>440
short が抜けてたので改良を加えてみた。
URLリンク(kansai2channeler.hp.infoseek.co.jp)
検索の順序の関係上お手本とは順番は異なるが、いちおう関数は拾えている


457:354 ◆zeyvxEAaZQ
08/11/09 05:42:14
[1] 授業単元: C++
[2] 問題文(含コード&リンク): 敵が一周回ったら再び中央へ移動して、波を描きながら画面外へ消える。これをクラスを使わないで作って欲しいです。
中央へ移動までは、>>395さんに作っていただきました。URLリンク(www.dotup.org)
最終的にこのような感じの動きです。URLリンク(www.dotup.org)
あと、敵の当たり判定もお願いします。これがサンプルです。URLリンク(www.dotup.org)
[3] 環境
 [3.1] OS: WindowsXP
 [3.2] コンパイラ名とバージョン: VC2005またはVC2008
 [3.3] 言語: C++
[4] 期限: ([2008年11月9日22:00まで
[5] その他の制限: クラスについてどのようなものかまだ習っていなかったのに、曖昧な返事をしてしまって申し訳ございません。
プログラムに関しては、自機の表示と弾を出すのはできましたが、それ以降ができません。どうかお願いします。

458:デフォルトの名無しさん
08/11/09 05:43:08
>>457
構造体はつかってもいいですか?

459:デフォルトの名無しさん
08/11/09 06:16:06
[1] 授業単元: C++
[2] 問題文(含コード&リンク):数個のポイントを含むクラスポリゴンを定義しなさい。
(a) デストラクター・コピーコンストラクター・アサインメントオペレーターを作成し、クラスを定義しなさい。ディフォルトコンストラクターは空のポリゴンを作成すると仮定しなさい。
(b)Pointクラスがプライベートメンバー、また、(x,y)を返すコンストラクタPoint(int, int)を持つように変更しなさい。そうすることによってポリゴンクラスがコンパイルしなくなります。問題点を発見し、修正しなさい。
(一応骨組みは作ってみました。)
class Point {
  public:
    float x;
    float y;}
class Polygon {
   Point * points; //the points
   int size; //number of points
  public:
   Polygon() {...};
   Polygon(const Point * pts, int n) {...};
   Point getPoint(int n)const {
    //n番目のポイントを返す}
   void setPoint(const Point& p, int n) {
    //sets the nth point}
   int getSize()const {
    return size;}};
 [3.1] OS: linux redhat
 [3.2] コンパイラ名とバージョン: VC2005またはVC2008
 [3.3] 言語: C++
[4] 期限: ([2008年11月11日22:00まで
[5] その他の制限:ポリゴンを作成するプログラムを作る課題を出されました。
  日本の皆さまのお力をお借りしたく、投稿させて頂きます。
  上の骨組みで作成することが、条件として出されました。
  よろしくお願いいたします。

460:デフォルトの名無しさん
08/11/09 07:49:14
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):
void Wa(int a,int b);
…2つの引数の和を計算し、結果を表示する(xとyの和)
int abs_Sa(int a, int b);
…2つの引数の差を計算し、その絶対値を返す(xとyの差の絶対値)
double Heikin(int a,int b, int c, int d int e);
…5つの引数の平均値を返す(num[5]の平均値)
このような演算を行う関数をそれぞれ定義し、下記のプログラムに処理を追加せよ

#include<stdio.h>
void Wa(int a,int b);
int abs_Sa(int a, int b);
double Heikin(int a,int b, int c, int d int e);

int main(void){
int k,x,y,num[5]={19,51,100,32,6};
double z;
printf("xを入力してください:")
scanf("%d",&x);
printf("yを入力してください:")
scanf("%d",&y);
/* これ以降に処理を追加する */
[3] 環境
 [3.1] OS: Windows XP
 [3.2] コンパイラ名とバージョン: Visual stdio 2005
 [3.3] 言語: C
[4] 期限: 11/11 18:00
[5] その他の制限:
関数習いたてです。よろしくお願いします

461:デフォルトの名無しさん
08/11/09 08:35:36
>>460
main 残り
printf("x + y = ");
Wa(x, y);
printf("\n");
k = abs_Sa(x, y);
printf("|x - y| = %d\n", k);
z = Heikin(num[0], num[1], num[2], num[3], num[4]);
printf("average of %d, %d, %d, %d, and %d = %f\n", num[0], num[1], num[2], num[3], num[4], z);
return 0;
関数
void Wa(int a, int b)
{
printf("%d", a + b);
}
int abs_Sa(int a, int b)
{
if (a >= b)
return a - b;
else
return b - a;
}
double Heikin(int a, int b, int c, int d, int e)
{
return (a + b + c + d + e) / 5.0;
}


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

長くなったので↓にアップします。

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

[3] 環境
 [3.1] OS: Windows XP
 [3.2] コンパイラ名とバージョン: VC2005またはVC2008
 [3.3] 言語: c++
[4] 期限: 11月12日
[5] その他の制限:
for文、if文、配列等まで習いました。よろしく御願いします。

463:デフォルトの名無しさん
08/11/09 10:09:10
[1] 授業単元:演習
[2] 問題文:
数値が何(バラバラ)行2列でかかれた複数のファイルがあり
それぞれのファイルを読み込み、表示させるプログラムを書きなさい。
何行かはファイルを開かないとわからないのでプログラムで行数をはかる。
[3] 環境
 [3.1] OS:LINUX
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語:C
[4] 期限:2008年11月9日

464:460
08/11/09 10:10:41
>>461
ありがとうございます、助かりました

465:デフォルトの名無しさん
08/11/09 10:58:28
>>462
メインのループの部分だけ

int pos = 0;
for(i = 0; i < 20; i++) {
x = rnd();
if (x < 0.3) {
pos--;
printf("左に進みました。");
} else {
pos++;
printf("右に進みました。");
}
printf("現在位置 ");
if(pos > 0)
printf("右に %d ", pos);
else if(pos < 0)
printf("左に %d ", pos);
else if(pos > 0)
printf("原点");
printf("です。\n");
}


466:465
08/11/09 11:04:45
ちょっと読み違えてたので訂正
double x;
int i, pos = 2;
char *place[] = {"盗賊", "湖", "入り口", "森", "宝"};

srand((unsigned int)time(NULL));

for(i = 0; i < 20; i++) {
x = rnd();
if (x < 0.3) {
pos--;
printf("左に進みました。");
} else {
pos++;
printf("右に進みました。");
}
if(pos >= 4){
printf("宝を見つけました。");
pos = 2;
} else if (pos <= 0){
printf("盗賊に会いました。");
pos = 2;
}
printf("現在位置 %s です。\n", place[pos]);
}


467:デフォルトの名無しさん
08/11/09 12:53:26
>>466

ありがとうございました!


468:デフォルトの名無しさん
08/11/09 13:16:10
[1] 授業単元:数値計算法1
[2] 問題文(含コード&リンク):

gyoretu[n][n]に格納された、n次の行列の逆行列を求め、出力するプログラムを作成せよ。

対角要素に0や0に近い要素があっても、正しく答えが求められるように工夫せよ。

[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: VC 6.0
 [3.3] 言語: C
[4] 期限:明日
[5] その他の制限: なし


お願いいたします!!

469:デフォルトの名無しさん
08/11/09 13:18:27
>>463
ファイル読んでその場で表示するだけなら行数とか考える必要ないんだけど
いったん全部読み込んだあとにまとめて表示するようにした方が良い?
#include <stdio.h>
#define MAX 256
int main(int argc, char **argv)
{
FILE *fp;
double a, b;
while(argc-- > 1){
fp = fopen(argv[argc], "r");
if(fp == NULL){
fprintf(stderr, "Cannot open %s\n", argv[argc]);
continue;
}
while(fscanf(fp, "%lf %lf", &a, &b) != EOF)
printf("%f %f\n", a, b);
fclose(fp);

}
return 0;
}


470:デフォルトの名無しさん
08/11/09 13:18:52
ライブラリ使ったほうが正確

471:デフォルトの名無しさん
08/11/09 14:43:22
>>415
返信遅れてすいません。
cinとcoutはやりました。
でも授業が難しいのでなかなか理解できないんですよね。。。


472:デフォルトの名無しさん
08/11/09 15:00:33
[1] 授業単元: C,C++、データ圧縮LZ78符合
[2] 問題文:以下に与えたデータ列をLZ78符合で圧縮し、画面に表示するプログラムを作成せよ。
      データ列:ABCBCBCDEBCDABCD
コンソールアプリケーションで作成すること。
      画面には最低限以下のものを出力すること。
      【1】与えたデータ列
      【2】作成した辞書の一覧
      【3】符号化したデータ列
[3] 環境
 [3.1] OS: WindousXP
 [3.2] コンパイラ名とバージョン: VisualStudio2005
 [3.3] 言語: C,C++どちらでも可
[4] 期限:2008年11月13日まで
[5] その他の制限: 標準ライブラリ可

よろしくお願いします。


473:デフォルトの名無しさん
08/11/09 15:13:53
>>458
構造体は使っても大丈夫です。

474:デフォルトの名無しさん
08/11/09 16:17:50
[1] 授業単元:C言語

[2] 問題文(含コード&リンク):
入力した値までの素数を列挙させるプログラムを作成せよ。
例)整数を入力:5
2は素数です
3は素数です
5は素数です

[3] 環境
 [3.1] OS: WindowsXP
 [3.2] コンパイラ名とバージョン: VisualStudio2005
 [3.3] 言語:C/C++/どちらでも可

[4] 期限: 2008年11月12日まで
[5] その他の制限:for文まで。できるだけ簡潔に。

よろしくお願いします。

475:デフォルトの名無しさん
08/11/09 16:32:24
>>474
なにも考えないDQNメソッドだけど
#include <stdio.h>
int main()
{
int i, j, n;
printf("整数を入力:");
scanf("%d", &n);
for(i = 2; i <= n; i++) {
for(j = 2; j < i; j++){
if (i % j == 0)
break;
}
if (j >= i)
printf("%d は素数です\n", i);
}
return 0;
}


476:学生
08/11/09 16:46:51
1から1000までの正の整数において、13の倍数の個数を出力するプログラム

よろしくお願いします

477:デフォルトの名無しさん
08/11/09 16:47:53
>>456
ありがとうございます!
面倒だったようで申しわけないです

478:デフォルトの名無しさん
08/11/09 16:48:32
>>476
#include <stdio.h>
main(){
printf("%d\n", 1000/13);
}


479:学生
08/11/09 16:48:35
訂正
マイクロソフトビジュアルベーシックC++で作成

480:デフォルトの名無しさん
08/11/09 16:50:17
>>479
>>476
#include <stdio.h>
int main(){
printf("%d\n", 1000/13);
return 0;
}


481:デフォルトの名無しさん
08/11/09 18:01:36
>>472
C++です。VS2008で確認。
URLリンク(kansai2channeler.hp.infoseek.co.jp)

482:デフォルトの名無しさん
08/11/09 18:51:28
[1] 授業単元: C言語
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)

[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:
 [3.3] C
[4] 期限:11月10
[5] その他の制限:出来るだけ簡単に

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

483:482
08/11/09 18:52:44
URL訂正します
URLリンク(kansai2channeler.hp.infoseek.co.jp)

484:デフォルトの名無しさん
08/11/09 19:11:25
>>483
#include <stdio.h>

int main(int argc, char *argv[])
{
unsigned int i, n;
char str[21];

puts("符号なし32ビット整数を入力してください。");
scanf("%u", &n);
printf("%u が格納されている先頭アドレスは 0x%p です。\n", n, &n);

puts("20文字以内の文字列を入力してください。");
scanf("%s", str);
printf("%s が格納されている先頭アドレスは 0x%p です。\n", str, str);
for (i = 0; str[i] != '\0'; i++) {
printf("%c が格納されているアドレスは 0x%p です。\n", str[i], &str[i]);
}
return 0;
}

485:457 ◆zeyvxEAaZQ
08/11/09 21:08:03
期限を11月9日23:30までにするので>>457をどうかお願いします。

486:デフォルトの名無しさん
08/11/09 22:53:54
1] 授業単元:プログラム
[2] 問題文(含コード&リンク):遺伝的プログラムで木構造に新しいノードを追加しなさい。
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:2008年11月11日まで
[5] その他の制限:
お願いします。

487:デフォルトの名無しさん
08/11/09 22:59:03
>>486
遺伝的プログラムってだけ言われても困るぞwwwwwwww
他になんか情報はないのか

488:デフォルトの名無しさん
08/11/09 23:17:23
>>487
例えばどういう情報があればいいですか?

489:デフォルトの名無しさん
08/11/09 23:22:37
>>485

cで書けと?

490:デフォルトの名無しさん
08/11/09 23:23:59
>>475
ありがとうございました。助かりました。

491:デフォルトの名無しさん
08/11/10 00:34:44
[1] 授業単元:C
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ名とバージョン:bcc
 [3.3] 言語:C
[4] 期限:11/11
[5] その他の制限:特になし

よろしくお願いします

492:デフォルトの名無しさん
08/11/10 00:43:01
宿題丸投げするつもりはないんだが質問させてくれないか
bccコンパイラを使っているんだ。

プログラムの実行時間測定に
#include <sys/time.h>
を参照したいんだがtime.hがどうも入ってないみたいなんだ。
標準搭載されてる関数で少数点以下まで実行時間を計れるものってないかな?

493:デフォルトの名無しさん
08/11/10 00:52:26
#include <time.h>
じゃねーの?

494:デフォルトの名無しさん
08/11/10 00:59:37
#include <sys/timeb.h>
だと思うが、Linux使いなので詳しくはしらないが
struct timeb now;
int millisec;

ftime(&now);
millisec = now.millitm; /* これがミリ秒らしい */
こんな感じだと思う。
詳しくは、ググるかヘッダファイル読め。

495:493
08/11/10 01:01:04
俺がいってたのは
#include <time.h>
のclock()ね


496:デフォルトの名無しさん
08/11/10 01:02:14
>>493
俺の探し方がアホなだけかもしれんが、#include <time.h>だと少数点以下まで測れる方法が見つからなかったんだorz
>>494
ありがとう
参考にする

497:デフォルトの名無しさん
08/11/10 01:04:32
>>495
ΣΣclock!!
見落してた マジサンキュ やってみる

498:デフォルトの名無しさん
08/11/10 01:26:15
>>489
C++でお願いします。

10日の18:00まででいいのでどうかお願いします!

499:デフォルトの名無しさん
08/11/10 01:27:58
>>498

クラスを使うなと書いてあるが?
そこだけ関数?

500:デフォルトの名無しさん
08/11/10 01:33:51
[1] 授業単元:C言語
[2] 問題文 
 初期設定された任意の文字列の順序を,逆に並べ換えるプログラムをつくりなさ
い。ただし,並べ換える部分を関数にして,関数には文字列を引数として渡しなさい。
文字列の例としては,
char str[] = "My name is Tarou Tanaka";
のように自分の名前を用いてみなさい。

[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語: C
[4] 期限: 2008年11月12日 24:00
[5] その他の制限:
・次のようなプロトタイプ宣言をもつ関数reverse を定義すること。
void reverse(char *);
・引数で渡された文字列自身が逆順になること。

C言語の基本関数のみでよろしくお願いします。

501:デフォルトの名無しさん
08/11/10 01:37:34
>>499
構造体はつかっていいらしいかららクラスと差し替えちゃえばいいんじゃね

502:デフォルトの名無しさん
08/11/10 01:57:40
>>499
クラスは使わず、構造体でお願いします。

503:デフォルトの名無しさん
08/11/10 02:10:50
>>502
ほんとうにいいんだな
構造体にコンストラクタとデストラクタとメンバ関数つけられるぞ?

504:デフォルトの名無しさん
08/11/10 02:11:50
>>500
void reverse(char * s)
{
size_t len = strlen(s); /* 文字列の長さ */
size_t half_len = len / 2; /* 文字列の半分の長さ */
size_t i;

for ( i = 0; i < half_len; ++i ) {
char tmp = *((s + len - 1) - i);
*((s + len - 1) - i) = *(s + i);
*(s + i) = tmp;
}
}
こんなのでいいかな。

505:デフォルトの名無しさん
08/11/10 02:21:28
[1] 授業単元:Cプログラミング
[2] 問題文:
#include <stdio.h>
#define SIZE 10
int main(void)
{
FILE *infile;
int i, data[SIZE];
infile = fopen("sample61a.txt", "r");
if(infile == NULL) {
printf("入力ファイルを開くことができません\n");
return 0;
}
for(i = 0; i < SIZE; i ++ ) {
fscanf(infile, "%d", &data[i]);
}
for(i = 0; i < SIZE; i ++ ) {
printf(" %3d", data[i]);
}
printf("\n");
return 0;
}

506:デフォルトの名無しさん
08/11/10 02:21:58
505の続きです。

このプログラムを改造し、データの値を奇数と偶数に分けそれぞれ合計値・個数・平均値を出力せよ。
その際奇数データの数、偶数データの数がそれぞれゼロの場合は平均値を求めないようにせよ。
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ:Microsoft Visual C++ 6.0
 [3.3] 言語:C
[4] 期限:11月11日

締め切りが急ですみません。
さっぱりわからなくなってしまったので、良ければよろしくお願いします。

507:デフォルトの名無しさん
08/11/10 02:39:50
>>504

ありがとう!

508:デフォルトの名無しさん
08/11/10 02:45:05
>>505
#include <stdio.h>
#define SIZE 10
int main(void)
{
FILE *infile;
int i, data[SIZE], sum[2]={0}, num[2]={0};
char *str[2] = {"奇数", "偶数"};

infile = fopen("sample61a.txt", "r");
if(infile == NULL) {
printf("入力ファイルを開くことができません\n");
return 0;
}

for(i = 0; i < SIZE; i ++ ) {
fscanf(infile, "%d", &data[i]);
sum[data[i]%2] += data[i];
num[data[i]%2]++;
}
for(i = 0; i < SIZE; i ++ ) {
printf(" %3d", data[i]);
}
printf("\n");

for(i=1; i>=0; i--){
printf("%s:合計値%d, 個数%d個", str[i], sum[i], num[i]);
if(num[i] > 0) printf(", 平均値:%f", (float)sum[i] / (float)num[i]);
printf("\n");
}
return 0;
}

509:デフォルトの名無しさん
08/11/10 02:46:41
あ、奇数と偶数の表示が逆

510:デフォルトの名無しさん
08/11/10 02:52:08
[1] 授業単元: OS
[2] 問題文(含コード&リンク):
ITIMER_REAL, ITIMER_VIRTUAL, ITIMER_PROF タイマーを用いて、プロセスのプロセッサ利用状況を測定するソフトウェアを実装する。
出力には、実行の経過時間、プロセッサ時間、ユーザ空間時間、カーネル空間時間が含むこと。
詳細
(1)すべての時間はミリ秒の分解精度を持つこと
(2)1秒毎にsignalを発生させ、経過した秒数をカウントする
(3)再帰を用いたFibbonacci数を計算するプログラムを子プロセスとした実行結果をしめすこと
[3] 環境
 [3.1] OS: Linux Kernel 2.6.x
 [3.2] コンパイラ名とバージョン: gcc4.x
 [3.3] 言語: C言語
[4] 期限: 2008年11月12日12:00
[5] その他の制限: sigactionやitimervalを用いて実装するのが今回の目的です。時間を計るものはできたのですが、ミリ秒単位の分解精度をどうやって出すのかがわかりません。よろしくお願いします。


511:デフォルトの名無しさん
08/11/10 02:54:37
510です。
稚拙ながらもソースコードを示します。
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <signal.h>
#include <unistd.h>
#include <sys/time.h>
#include <sys/types.h>
#include <sys/wait.h>
int realSec = 0;
int profSec = 0;
int virtualSec = 0;
static void myHandler(int s) {
int errSave;
if (s == SIGALRM) realSec++;
else if (s == SIGVTALRM) virtualSec++;
else if (s == SIGPROF) profSec++;
}
static int setupInterrupt(void) {
struct sigaction act;
act.sa_handler = myHandler;
act.sa_flags = 0;
return (sigemptyset(&act.sa_mask) == sigaction(SIGALRM,&act, NULL) == sigaction(SIGVTALRM,&act, NULL) == sigaction(SIGPROF, &act, NULL) == 0) ? 1 : 0;
}
static int setupitimer(void) {
struct itimerval value;
value.it_interval.tv_sec = 1; value.it_interval.tv_usec = 0;
value.it_value = value.it_interval;
return (setitimer(ITIMER_PROF,&value, NULL) == setitimer(ITIMER_VIRTUAL,&value, NULL) == setitimer(ITIMER_REAL,&value, NULL) == 0)? 0: -1 ;
}


512:デフォルトの名無しさん
08/11/10 02:56:23
510です。続きです。
int main(int argc, char** argv) {
pid_t child, retVal;
struct itimerval real, virtual, profile;
int status;
if (setupInterrupt()) {
perror("Failed to set up handler for SIGPROF"); return 1;
}
if (setupitimer() == -1) {
perror("Failed to set up the ITIMER_PROF intervaltimer");return 1;
}
if (argc < 2){
fprintf (stderr, "Usage:%s command\n", argv[0]);return 1;
}
if ((child = fork()) == -1) {
perror("Failed to fork"); return 1;
}
if (child == 0) { // child code
execvp(argv[1], &argv[1]);
perror("Child failed to execvp the command");
return 1;
} else { // parent code
while((retVal = waitpid(-1, &status, WNOHANG)) != child);
getitimer(ITIMER_REAL, &real);getitimer(ITIMER_PROF, &profile);getitimer(ITIMER_VIRTUAL, &virtual);
//ここも要修正
printf("real = %d.%ld", realSec, 1000000 - real.it_value.tv_usec);
printf(" virtual = %d.%ld", virtualSec, 1000000 - virtual.it_value.tv_usec);
printf(" profile = %d.%ld\n", profSec, 1000000 - profile.it_value.tv_usec);
}
}
よろしくお願いします。

513:デフォルトの名無しさん
08/11/10 03:19:23
[1]授業単元:C言語
[2] 問題文:次のことを行うプログラムを,for文を用いて作成しなさい。
10個の要素をもつ整数配列dataを初期化して宣言する。
配列要素の中の最大値と最小値を出力しなさい。
なお,配列要素の値として,すべて負のものがあるデータも試してみること。
[3] 環境
[3.1] OS:Win
[3.2] コンパイラ名とバージョン:VC++ 6.0
[3.3] 言語:C言語
[4]期限:なし

初歩的な問題で申し訳ないですが、よろしくお願いします。

514:デフォルトの名無しさん
08/11/10 03:30:10
>>513
#include <stdio.h>
#define SIZE 10
int main() {
//int data[SIZE] = {83,28,35,84,43,21,8,51,2,12};
int data[SIZE] = {-83,-28,-35,-84,-43,-21,-8,-51,-2,-12};
int min, max;
int i;

min = max = data[0];
for (i = 1; i < SIZE; i++) {
if (data[i] > max) {
max = data[i];
} else if (data[i] < min) {
min = data[i];
}
}
printf("min = %d, max = %d\n", min, max);
}



515:デフォルトの名無しさん
08/11/10 05:45:39
>>503
はい、お願いします。

516:デフォルトの名無しさん
08/11/10 05:47:28
追記

>>503
クラス使わないで、構造体で作って動けば問題ないのでお願いします。

517:デフォルトの名無しさん
08/11/10 08:36:06
[1] 授業単元: プログラミング
[2] 問題文(含コード&リンク): URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境:
 [3.1] WindowsVista
 [3.2] Borland C++Compiler
 [3.3] C言語
[4] 期限: 2008年11月10日23:59まで

518:デフォルトの名無しさん
08/11/10 09:02:31
>>514
ありがとうございます!

519:デフォルトの名無しさん
08/11/10 09:12:11
>>517

#include <stdio.h>
void main(void){
int i,t;t=0;
for(i=1; i<=100; i++){if(i %3 == 0){printf("%d \n" ,i);t++;}}
printf("\n total %d\n",t);}

520:デフォルトの名無しさん
08/11/10 11:43:48
>>511
どうでもいいところかもしれんが

return (sigemptyset(&act.sa_mask) == sigaction(SIGALRM,&act, NULL) == sigaction(SIGVTALRM,&act, NULL) == sigaction(SIGPROF, &act, NULL) == 0) ? 1 : 0;

これ、意図したとおりに動くの? A == B は A と B が等しかったら 1 を返すよ

一つでも 0 以外のを返したら、とやりたいんだったら && とか使うべし

521:デフォルトの名無しさん
08/11/10 13:44:10
[1] 授業単元:データ構造とアルゴリズム
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: UNIX
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 11月12日
[5] その他の制限: 特になし

よろしくお願いします。

522:デフォルトの名無しさん
08/11/10 14:06:25
>>521 該当箇所だけ。push, pop はもうできてるんでしょ?
while(!isempty()) {
y = pop();
x = pop();
if (map[y][x] == ' ') {
map[y][x] = '*';
/*ここを適切に埋める(3) */
// up
push(x);
push(y - 1);
// down
push(x);
push(y + 1);
// left
push(x - 1);
push(y);
// right
push(x + 1);
push(y);
/*塗るたびにマップを表示する */
for(y = 0; y < 7; y++)
printf("%s\n", map[y]);
printf("\n");
}
}


523:374
08/11/10 14:22:12
すいません誰か>>374をお願いします。もう締め切りも近いのでどうか頼みます

524:デフォルトの名無しさん
08/11/10 14:28:40
>>508
ありがとうございます!助かりました!

525:デフォルトの名無しさん
08/11/10 14:37:57
>>523
1年分ってのは、入力した年の1月から12月を表示すればよいのか
入力した月から翌年の同月-1 を表示すればよいのか
入力した月を含む前後6か月を表示すればよいのか


526:デフォルトの名無しさん
08/11/10 15:02:16
>>523
カレンダーは >> 525 の返答次第
フィボナッチその1
#include <stdio.h>
int main()
{
int i, f0 = 0, f1 = 1, f2 = 1, num;
printf("num:");
scanf("%d", &num);
for(i = 0; i < num; i++){
printf("f[%d]:%d\n", i, f0);
f2 = f1 + f0;
f0 = f1;
f1 = f2;
}
return 0;
}


527:デフォルトの名無しさん
08/11/10 15:02:58
>>523
フィボナッチその2
#include <stdio.h>

int main()
{
int i, f0 = 0, f1 = 1, f2 = 1, num;
printf("num:");
scanf("%d", &num);

i = 0;
while(i < num){
printf("f[%d]:%d\n", i, f0);
f2 = f1 + f0;
f0 = f1;
f1 = f2;
i++;
}
return 0;
}


528:デフォルトの名無しさん
08/11/10 15:03:33
>>523
フィボナッチその3
#include <stdio.h>

int main()
{
int i, f0 = 0, f1 = 1, f2 = 1, num;
printf("num:");
scanf("%d", &num);

i = 0;
do{
printf("f[%d]:%d\n", i, f0);
f2 = f1 + f0;
f0 = f1;
f1 = f2;
i++;
} while(i < num);
return 0;
}


529:初心者
08/11/10 15:59:23
[1] 授業単元:
[2] 問題文(含コード&リンク):
★下記の仕様を満たすプログラムをC言語で作成しなさい.

【仕様】日数計算プログラム

▼今日の日付と生年月日を入力すると,今日が生年月日から数えて何日目にあたるかを表示する.西暦・月・日をスペースで区切って入力する.
▼この場合,「うるう年」を考慮しなければならない.「うるう年」の条件は,
①西暦が4で割り切れる.
②ただし,西暦が100で割り切れる年は除く.
③ただし,西暦が400で割り切れる年は含める.
▼「今日は、あなたが生まれた日から数えて~日目です。」と表示する.
▼計算式は,(西暦1年1月1日から今日までの日数)-(西暦1年1月1日から生年月日までの日数)を使えばよい.
▼生年月日が今日の日付より後になっているときは,「生年月日が今日の日付より後になっています!」とエラーメッセージを表示する.
▼最低限,次の関数を使うこと.
①main関数(これは当たり前ですが)
②入力された値が計算に適切な値かをチェックする関数(4月31日などありえない日付を入れると,「年月日が正しい範囲にありません」と表示する)
③日付を計算する関数
▼日付の入力やメッセージの表示はmain関数で行うこと(ポインタに関する課題なので参照渡しを使うこと).

[3] 環境
 [3.1] OS: Windows xp
 [3.2] コンパイラ名とバージョン: 分からないです。
 [3.3] 言語: C言語
[4] 期限: 今週中ぐらい
[5] その他の制限: 繰り返し文、条件判断文、ポインタを使ってお願いします。
初心者なので、初心者にも分かるようなプログラムをお願いします。

530:デフォルトの名無しさん
08/11/10 16:09:07
課題が出たんですが、まったく手に負えません、、、、、
ぜひ、教えてください!
今、XPでvisualを使ってます。

『課題』
円周率πの値を近似式

π≒4Σ(←n=0から100で)(ー1)^n×(2n+1)^(-1)×{(0.5)^(2n+1)+(3)^(ー2nー1)}
を用いて、小数第8位まで正しい値(3.14159265)を出力し、
そのπの値を用いて入力された数値εに大して、次の不等式を満たす最小の自然数Nを求めるプログラムを作れ。
|(π^2/6)-Σ(←k=1からN)k^(-2)|<ε

531:デフォルトの名無しさん
08/11/10 16:32:39
viの正式名称なんて久しぶりに見たな

532:デフォルトの名無しさん
08/11/10 16:45:16
>>530
こんなんでいい?
#include <stdio.h>
#include <math.h>

int main (void)
{
int i;
double pi, sum, eps;

sum = 0.0;
for(i=0; i<=100; i++){
pi = 4.0 * (sum += pow(-1, i) / (2*i + 1) * (pow(0.5, 2*i+1) + pow(3, -2*i-1)));
}
printf("π≒%.8f\n", pi);

printf("ε:");
scanf("%lf", &eps);

i = 1; sum = 0.0;
while(fabs(pi*pi/6 - (sum += pow(i, -2))) >= eps)
i++;
printf("N = %d\n", i);

return(0);
}

533:デフォルトの名無しさん
08/11/10 17:06:14
誰か>>457をお願いします。
期限は今日中で良いのでお願いします!

534:デフォルトの名無しさん
08/11/10 17:48:20
printf("ε:");
かわいいな

535: ◆25LbU5YSxg
08/11/10 18:09:49
[1] 授業単元:プログラミング演習
[2] 問題文:
プログラム1を改良し、データをファイルから読み込みつつ小さい順にソートして格納するプログラムを作成せよ、。
手順を以下に示す。
1.cell構造体へのポインタとして、struct cell *new、*start、*p1、*p2;の4つを準備し、それぞれNULLで初期化する。
2.データファイルからデータ数を読み込む。
3.データを1つ読み込み、cell構造体を作成してnewにセットした後、その構造体に格納。
  ・はじめてのデータであれば、ポインタstartとp1をnewにセット。
  ・2つ目のデータであれば、p2をnewにセットし、p1が示すリスト要素(構造体)の次に追加接続する。
   ただし、2つ目のデータが1つ目のデータよりも小さい場合には、p1とp2の指す構造体内のデータを入れ替える。
   もしくはリスト要素(構造体)自体の位置を入れ替えポインタをセットし直す必要があることに注意。
  ・3つ目以降のデータであればリスト先頭から順に走査を行う。この際、p1、及びp2をそれぞれ1つずつリスト内の次の要素に進めてゆく。
   。読み込まれたデータが、リスト先頭要素(構造体)の持つ値より小さい場合には、新規作成された構造体newをリスト先頭に追加し、ポインタstartをnewにセットする。
  
   。リスト途中で、p1には読み込まれたデータより小さい値、p2には読み込まれたデータより大きい値となる場所が見つかれば、この間に新規作成された構造体newを挿入する。
  
   。リスト最後尾まで読み込まれたデータより大きい値が見つからなければ、新規作成された構造体newを最後尾に追加する。
4.3をデータ入力数だけ繰り返す。
5.全てのデータを読み込み終えたら、リスト先頭から順にデータを出力する。

num-data.txt
5
23
43
67
14
9



536: ◆25LbU5YSxg
08/11/10 18:15:43
プログラム1
#include<stdio.h>
struct cell{
int data;
struct cell *next; };
int main(void){
int num;
struct cell *new, *start, *ptr;
new = NULL;
start = NULL;
ptr = NULL;
while(1){
scanf("%d",&num);
if(num == -1){ break; }
new= (struct cell *)malloc(sizeof(start));
if(new == NULL){ fprintf(stderr,"Error!:malloc short(struct cell).\n"); }
new->data = num;
new->next = NULL;
if(ptr == NULL){
start = new;
ptr = new;
}else{
ptr->next=new;
ptr = new; } }
ptr = start;
while(ptr != NULL){
printf("%d\n",ptr->data);
ptr=ptr->next; }
return 0;}
[3] 環境 [3.1] OS: Linux[3.2] コンパイラ名とバージョン:gcc [3.3] 言語: C
[4] 期限:2008年11月21日17:00まで


537:デフォルトの名無しさん
08/11/10 18:18:32
>>529
URLリンク(kansai2channeler.hp.infoseek.co.jp)
参照渡しをする合理的理由がみあたらないので抜きで作った。
どっか適当に変えてくれ

538:374
08/11/10 19:36:44
>>525>>526
カレンダーは入力した年の1月から12月を表示するものでよかったです。

>>526-528
助かります。本当にありがとうございます

539:525
08/11/10 20:03:17
>>538
URLリンク(kansai2channeler.hp.infoseek.co.jp)

540:374
08/11/10 20:27:03
>>539
もうなんとお礼を言えばよいのかわかりません。本当にありがとうございました。

541:デフォルトの名無しさん
08/11/10 21:12:16
>>535
#include<stdio.h>
#include<stdlib.h>
struct cell {
int data;
struct cell *next;
};
int main(void){
int num;
struct cell *new, *start, *p1, *p2;
new = start = p1 = p2 = NULL;
while (1) {
scanf("%d", &num);
if (num == -1) break;
new = (struct cell *) malloc(sizeof(start));
if (new == NULL) { return 1; }
new->data = num;
new->next = NULL;
for(p1=start,p2=NULL; (p1) && new->data > p1->data; p2=p1, p1=p1->next);
if(p2){
p2->next = new;
new->next = p1;
}else{
new->next = start;
start = new;
}
}
for (p1=start; (p1); p1=p1->next) { printf("%d\n", p1->data); }
return 0;
}

542:デフォルトの名無しさん
08/11/10 22:01:28
[1] 授業単元:プログラミングC演習
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: Unix
 [3.2] コンパイラ名とバージョン: gcc(versionは不明
 [3.3] 言語: C
[4] 期限: 2008年11月13日(木曜日)12:00まで
[5] その他の制限: (どこまで習っているか、標準ライブラリは使ってはいけない等々)
・ポインタをメインに使用してください

よろしくお願いします

543:デフォルトの名無しさん
08/11/10 23:11:51
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク)
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 2008年11月12日
[5] その他の制限:

よろしくお願いいたします。

544:デフォルトの名無しさん
08/11/10 23:14:37
>>542
malloc は ok なの?
最大長とか単語数は別プログラムで調べるんだったらいいけど、
一度にやるんだったら必ず必要だよ

545:デフォルトの名無しさん
08/11/10 23:22:34
>>543
printf("学籍番号:%d 氏名:%s\n",
p->id, p->name);
○○○   //pに次の構造体のポインタを代入
   ↑↑↑
ここを p = p->next とやるだけでとりあえず動くものはできるけど・・・

List3 は点数を取り込んでないよね。点数を取り込むようにしたいの?
読み込むデータのサンプルはないの?

546:デフォルトの名無しさん
08/11/10 23:25:53
>>542
ツッコミどころが多すぎるんだが・・・

とりあえず
- char *dict[999], *input[50]
+ char dict[999][100], input[50][100]
として、適当に文字列を格納する領域を確保しておくこと。

勘違いだと思うけど
- for(i = 0; scanf("%s",input[i]) != '\n'; i++);
+ for(i = 0; scanf("%s",input[i]) == 1; i++);

添字が逆
- judge = compare( dict[j], input[k]);
+ judge = compare( dict[k], input[j]);

それから、そもそも input[j] に入っているのは標準入力から得た一行だから、単語ごとに分割する処理が必要

547:デフォルトの名無しさん
08/11/10 23:36:49
[1] 授業単元:Cプログラミング
[2] 問題文(含コード&リンク):
10 個の要素をもつ整数配列data を初期化して宣言する。
配列の隣り合った添え字のデータ同士の差(data[i] – data[i-1])を調べる。
その値が,最も大きなものを探し,データの差がい
くつなのか,添え字の何番と何番との間の差なのか出力しなさい。
最大のものが複数あったときには,添え字の最も大きなものを出力すること。
例えば,data[10]={-6,4,7,-3,-1,9,5,-5,4,6}
で初期化したときには,4 と5 の間の10 が最大となる。
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ名とバージョン:VC++ 6.0
 [3.3] 言語:C言語
[4] 期限:11/14
[5] その他の制限:特になし

よろしくお願い致します。

548:デフォルトの名無しさん
08/11/10 23:45:02
>>547
6,7番目の間の10が最大値になる?

549:デフォルトの名無しさん
08/11/10 23:46:40
>>547
素直に書いてみた
差の絶対値じゃなくて差の比較だけでいいんだよね?
#include<stdio.h>
#define N 10
int main(){
    int data[N]={-6,4,7,-3,-1,9,5,-5,4,6};
    int*max_diff = data;
    int*it;
    for(it=data+1;it!=data+N-1;++it)
        if(1[max_diff]-0[max_diff] <= 1[it]-0[it])
            max_diff = it;
    printf("%dと%dの間の差%dが最大\n",
        max_diff-data,max_diff-data+1,1[max_diff]-0[max_diff]);
    return 0;
}

550:デフォルトの名無しさん
08/11/11 00:50:44
[1] 授業単元: プログラミング
[2] 問題文(含コード&リンク):
一次元配列を用いて5人分の得点を100点満点で入力し、平均値を画面およびファイルに書き出すプログラムを作成しなさい。
書き出し用ファイル名はave.txtとする。
[3] 環境:
 [3.1] Windows Vista
 [3.2] Borland C++
 [3.3] C言語
[4] 期限: 11月11日12:00

昼すぎ提出なので時間があまりないですが、どなたかお願いします。

551: ◆8w4FYxc7TQ
08/11/11 00:52:24
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):
三つの数字a,b,cを入力したとき、大きい順に出力するプログラムを作成せよ。
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ名とバージョン:VC++ 9.0
 [3.3] 言語:C++
[4] 期限:11/12
[5] その他の制限:
この問題で使えそうなものは、if、もしくはswitchしか習っていないので、それでお願いします。

自分でif文を使って組み立てると、どうしても思い通りに並べてくれません…
どうかよろしくお願いします。

552:デフォルトの名無しさん
08/11/11 01:11:20
[1] 授業単元: C言語演習
[2] 問題文(含コード&リンク): URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: (Windows vista)
 [3.2] コンパイラ VisualStudio2005
 [3.3] 言語: C言語
[4] 期限: 2008年11月13日15:00まで
[5] その他の制限: (C言語検定2級程度の途中まで習ってます)

すいません、お願いします


553:デフォルトの名無しさん
08/11/11 01:17:33
>>491お願いできませんか?

554:デフォルトの名無しさん
08/11/11 01:25:42
>>549
はい、差の比較のみです。
言葉が足りなくてすみません。
ありがとうございました!

555:521
08/11/11 01:34:59
>>522
ありがとうございます。

誰か、もう一つの課題のほうもお願いいたします。

556:デフォルトの名無しさん
08/11/11 01:46:23
>>550
#include <stdio.h>

int main(void)
{
int i, score, sum=0;
FILE *fp;

for(i=1; i<=5; i++){
printf("%d人目:", i);
scanf("%d", &score);
sum += score;
}
printf("平均値:%f\n", (double)sum / 5.0);

if((fp = fopen("ave.txt", "w")) == NULL){
printf("ファイルが開けません\n");
return 1;
}
fprintf(fp, "平均値:%f\n", (double)sum / 5.0);
fclose(fp);

return 0;
}

557:デフォルトの名無しさん
08/11/11 01:48:54
ああ、配列使うのか
#include <stdio.h>

int main(void)
{
int i, score[5], sum=0;
FILE *fp;

for(i=0; i<5; i++){
printf("%d人目:", i+1);
scanf("%d", &score[i]);
sum += score[i];
}
printf("平均値:%f\n", (double)sum / 5.0);

if((fp = fopen("ave.txt", "w")) == NULL){
printf("ファイルが開けません\n");
return 1;
}
fprintf(fp, "平均値:%f\n", (double)sum / 5.0);
fclose(fp);

return 0;
}


558:デフォルトの名無しさん
08/11/11 01:57:47
>>551
if(a < b){
tmp = a;
a = b;
b = tmp;
}
if(a < c){
tmp = a;
a = c;
c = tmp;
}
if(b < c){
tmp = b;
b = c;
c = tmp;
}

559:デフォルトの名無しさん
08/11/11 02:18:50
>>481
お礼おくれて申し訳ありません。
助かりました。ありがとうございます。

560:デフォルトの名無しさん
08/11/11 02:33:03
>>556-557
ありがとうございます助かりました!
一次元配列使うんです、まぎらわしくてすいません。
二度もありがとうございました。

561:デフォルトの名無しさん
08/11/11 02:39:30
>>552
2番はちょっと余計なこともしてるけど
URLリンク(kansai2channeler.hp.infoseek.co.jp)

562:デフォルトの名無しさん
08/11/11 03:37:42
>>561
rewind(stdin)なんて標準以外の使い方すんなカス

563:デフォルトの名無しさん
08/11/11 03:49:35
[1] 授業単元:
[2] 問題文
0~9の数字のみからなる文字列を引数として受け取り、
同じ数字並びの整数を返す関数ascii2int()を作り、動作を
確認せよ。ただし、非負の整数のみ考える。
 [3.1] OS:linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語: c
[4] 期限: 11月15日

564:デフォルトの名無しさん
08/11/11 03:56:49
[1] 授業単元:スタック
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ名とバージョン:VC 6.0
 [3.3] 言語:C
[4] 期限:2008/11/12
[5] その他の制限:なし

すいませんが、よろしくお願いします!



565:デフォルトの名無しさん
08/11/11 06:51:39
>>562
これで許してくださいorz
scanf("%*[^\n]\n");

566:デフォルトの名無しさん
08/11/11 06:59:11
>>563
#include<stdio.h>
int ascii2int(const char* str){
int r=0;
while(*str){
r*=10;
r+=*str-'0';
str++;
}
return r;
}
int main(){
char* a = "12345";
printf("%d\n",ascii2int(a));
}

567:デフォルトの名無しさん
08/11/11 07:36:20
>>564
なんかへたくそでごめん。。
#include<stdio.h>
#define N 100
int n,cnt=0,c[N],b[N];
void solve(int a_top,int b_top,int c_top){
if(a_top>n && b_top==0){
int i;
for(i=0;i<n;i++)printf("%d",c[i]);
printf("\n"); cnt++;
}
if(a_top<=n){
b[b_top++] = a_top++;//a->b
solve(a_top,b_top,c_top);
b[--b_top] = --a_top;//b->a
}
if(b_top>0){
c[c_top++]=b[--b_top];//b->c
solve(a_top,b_top,c_top);
b[b_top++]=c[--c_top];//c->b
}
}
int main(){
printf("n:"); scanf("%d",&n);
if(n>0) solve(1,0,0);
printf("%d\n",cnt);
}

568:デフォルトの名無しさん
08/11/11 07:40:51
>>558
ありがとうございます!
やってみます!

569:デフォルトの名無しさん
08/11/11 08:52:57
>>555
2回に分けて。
#include<stdio.h>
#define STACKSIZE 100
typedef struct _Point{
int x,y;
}point;
static int sp = 0;
static point stack[STACKSIZE];
void push(point p){
[sp++] = p;
}
point pop(void){
return stack[--sp];
}
int isempty(void){
return sp == 0;
}


570:デフォルトの名無しさん
08/11/11 08:54:32
//上の[sp++] = p;はstack[sp++] = p;のミス!!
int main(void){
char map[7][11] = {
"**********",
"* * *",
"* *****",
"* ** * *",
"* * *",
"* * * *",
"**********",
};
point p;
int x,y;
p.x=2; p.y=1; push(p);
while(!isempty()){
p=pop(); x=p.x; y=p.y;
if (map[y][x] == ' '){
map[y][x] = '*';
p.x=x; p.y=y-1; push(p); // up
p.x=x; p.y=y+1; push(p); // down
p.x=x-1; p.y=y; push(p); // left
p.x=x+1; p.y=y; push(p); // right
for(y = 0; y < 7; y++) printf("%s\n", map[y]);
printf("\n");
}
}
return 0;
}


571:564
08/11/11 09:00:54
>>567
こんなに早く対応していただけて助かります。
ありがとうございます!

572:デフォルトの名無しさん
08/11/11 10:08:37

[2] 1. define文を使ってN以下の素数を全て求めよ
  2. 関数 f(t)=t^5-t の区間 [0,2] での値を 0.1 刻みで表示するプログラムを作れ
[3]
 [3.1] OS : Linux
 [3.2] ?
 [3.3] 言語 : C
[4] 期限: 11/12
[5] その他の制限:初歩の初歩です。難しすぎるのはよく分かりません

どなたかよろしくお願いします


573:デフォルトの名無しさん
08/11/11 11:06:09
1こめ
#include<stdio.h>
#define N 100
int main(){
int s[N],i,j;
for(i=0;i<N;i++) s[i]=1;
s[0] = s[1] = 0;
for(i=2;i<N;i++){
if(!s[i]) continue;
for(j=i+i;j<N;j+=i){
s[j]=0;
}
}
for(i=0;i<N;i++){
if(s[i]) printf("%d\n",i);
}
}

574:デフォルトの名無しさん
08/11/11 11:14:17
>>573
define文を使うって、#define N 100 ← これだけでいいのかww

575:デフォルトの名無しさん
08/11/11 11:15:35
えっ?だめ??勘違い?(´・ω・`)

576:デフォルトの名無しさん
08/11/11 11:58:52
>>521じゃないけど分からないので質問。>>522の通りにやっても何も表示されないので
たぶん確実に違うisemptyのどこが駄目でしょうか?あとpush,popもおかしかったら教えてください。

void push(int x){
if(sp == 100){
printf("stack is fill.\n");
}
else{
stack[sp]=x;
sp++;
}
}
int pop(void){
if(sp == 0){
printf("stack is empty.\n");
}
else{
sp--;
return(stack[sp]);
}
}

int isempty(void)
{
if(sp ==100)
printf("1");
if(sp ==0)
printf ("0");
}

577:522
08/11/11 12:03:42
>>576
void push(int val)
{
stack[sp++] = val;
}
int pop(void)
{
return stack[sp-- - 1];
}
int isempty(void)
{
/*スタックが空なら1、空でないなら0を返す関数 */
return sp == 0 ? 1 : 0;
}


578:デフォルトの名無しさん
08/11/11 12:08:04
stack[sp++] = val;
は普通だけど、
return stack[sp-- - 1];
って書き方がすごくきもく見えるw

579:デフォルトの名無しさん
08/11/11 12:13:05
return stack[--sp];
だよなぁ常考

580:522
08/11/11 12:37:34
>>578>>579
貼ってから自分でもそうオモタ

581:デフォルトの名無しさん
08/11/11 12:59:00
個人的に
論理式?1:0;とかif(論理式!=0)とかif(論理式==0)
って書き方が好きじゃない。冗長な感じがして。

582:デフォルトの名無しさん
08/11/11 13:01:58
真の時に1を返すと保障されている処理系ならば return sp == 0; でもいいんだけどね


583:デフォルトの名無しさん
08/11/11 13:03:56
C言語は保証されてる

584:デフォルトの名無しさん
08/11/11 14:01:00
[1] 授業単元:C言語
[2] 問題文(含コード&リンク):
以下のプログラムを英文清書プログラムに書き換えよ。
元のプログラム
URLリンク(kansai2channeler.hp.infoseek.co.jp)
条件
・文の先頭は大文字、それ以外は小文字。
・アルファベット以外の文字は変換しなくてよい。
・改行、スペース、タブにより単語の区切りとする。また文末は改行コードではなくピリオド"."で判定する。
・\endまたは\ENDを挿入するとそのプログラムを終わるようにする。
[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 2008/11/12 23:59まで
[5] その他の制限: 特にないです。
すみませんが、よろしくお願いします。

585:デフォルトの名無しさん
08/11/11 14:34:13
INExp.hって??

586:デフォルトの名無しさん
08/11/11 15:28:24
isalphaとtoupper使えればいいのかな
ピリオド検索はstrstrで ポインタアドレスの差を文字列長にもしてげへへへ

587:デフォルトの名無しさん
08/11/11 16:00:13
[1] 授業単元:単方向線形
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限: 11/18
[5] その他の制限: 特になし

全く分かりません。宜しくお願いします

588:デフォルトの名無しさん
08/11/11 16:12:52
>>587
うそつけw
考える気がないだろw

589:デフォルトの名無しさん
08/11/11 17:34:32
それを言ったらこのスレの存在意義がなくなるわけだが

590:デフォルトの名無しさん
08/11/11 17:36:25
どこのスレにだって黙ってればいいのに野暮ったい突っ込みする奴居るじゃん。

591:デフォルトの名無しさん
08/11/11 18:18:38
>>573
ありがとうございます

592:デフォルトの名無しさん
08/11/11 18:19:28
>>587
超めんどくさい!cの単方向リスト嫌い!
URLリンク(kansai2channeler.hp.infoseek.co.jp)

593:576
08/11/11 18:22:40
>>577
ありがとうございます。>>522と合わせてプログラムにしてみたんだが何もマップされないんです。

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

自宅のubuntuのgcc(おそらくでやってるんですが環境のせいですか?変なところあったら指摘お願いします。


594:デフォルトの名無しさん
08/11/11 18:24:58
printf("%s\n", map[y]);


595:デフォルトの名無しさん
08/11/11 18:25:43
ごめんかんちがい

596:デフォルトの名無しさん
08/11/11 18:28:38
あ!コピペミスってるだけじゃん~

597:デフォルトの名無しさん
08/11/11 18:49:43
a

598: ◆25LbU5YSxg
08/11/11 18:52:30
>>541
遅れましたが、解答ありがとうございました。


599:577
08/11/11 19:21:30
>>593
map データがなんだかやせ細ってるよ

600:デフォルトの名無しさん
08/11/11 20:20:46
1] 授業単元: C言語
[2] 問題文(含コード&リンク):
(1) 単項式を入力された順に出力されるように変更する
(2)入力した単項式を次数の大きい順にするに出力されるように変更する
ソースは以下を参考にしてください、たらない変数は任意で増やしてけっこうです
URLリンク(kansai2channeler.hp.infoseek.co.jp)
(1)と(2)は別解答

[3] 環境
 [3.1] OS: Win
 [3.2] コンパイラ名とバージョン: 任意
 [3.3] 言語: C
[4] 期限: 2008年11月14日13:30まで
期限が迫ってるのでお願いします


601:デフォルトの名無しさん
08/11/11 20:28:18
この問題昔見たなw

602:デフォルトの名無しさん
08/11/11 20:32:57
すいません
前スレあたりで載せたんですがスルーだったようで自力でやろうとしたけど無理だったので再度^^;
最終期限がすぐであせってます

603:576
08/11/11 20:35:35
なんというミス(^o^)
みなさまありがとうございました。明日も生きていけそうです。

604:デフォルトの名無しさん
08/11/11 20:37:29
[1] 授業単元: 文字列操作
[2] 問題文:
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:Linux
 [3.2] cc
 [3.3] C
[4] 期限:2008年11月12日15:00まで
[5] その他の制限:問題文中に出てくる、frequency.c を利用せよ、とありますので、
なるべくそれを基盤にするようにお願いします。

↓途中まで考えてみたものです。
URLリンク(kansai2channeler.hp.infoseek.co.jp)

605:デフォルトの名無しさん
08/11/11 20:45:38
>>604
1問目
freqency.c の出力部分を以下のように修正
for(i = 0; i < 26; i++) { /* 結果出力 */
while(alpha[i]-- > 0)
printf("*");
printf("\n");
}


606:605
08/11/11 20:54:39
>>604 2問目 main の中身だけ
char c;
int i, j, alpha[26], max = 0;
for(i = 0; i < 26; i++) /* 配列のクリア */
alpha[i] = 0;
c = getchar();
while(c != '\n') {
if (c >= 'a' && c <= 'z') { /* 英小文字の処理 */
alpha[c - 'a'] += 1;
if (alpha[c - 'a'] > max)
max = alpha[c - 'a'];
} else {
if (c >= 'A' && c <= 'Z') { /* 英大文字の処理 */
alpha[c - 'A'] += 1;
if (alpha[c - 'A'] > max)
max = alpha[c - 'A'];
}
}
c = getchar();
}
for(i = 0; i < max; i++) {
for(j = 0; j < 26; j++) { /* 結果出力 */
if (alpha[j] >= max - i)
printf("* ");
else
printf(" ");
}
printf("\n");
}
for(j = 0; j < 26; j++) /* 結果出力 */
printf("%c ", j + 'a');
printf("\n");

607:デフォルトの名無しさん
08/11/11 20:59:53
すいません・・>>491をお願いします・・

608:デフォルトの名無しさん
08/11/11 21:09:56

[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク): 問1、ユークリッドの法則を使ってn(n≦100)個の正整数の最大公約数を求めるプログラムを作れ
なお、最終的にはgcd(最大公約数を求める整数の羅列)=結果と画面上に表示するようにすること

問2、n個(n≦100以下)の正整数の最小公倍数を求めよ。
表示方法は先ほどの問いと一緒


[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:11/13
[5] その他の制限: int gcd(int x, int y)の関数を使用してください
あと、なるべく2つずつ比べるようにして、必ず大きい正数が変数xに入るようにしてください


609:デフォルトの名無しさん
08/11/11 21:15:18
>>607
ボールの初速とか角度は風の影響が全く無いときに当たるようにすればいいの?
それとも投げたら絶対当たるように作るの?

610:デフォルトの名無しさん
08/11/11 21:18:17
[1] 授業単元:C
[2] 問題文(含コード&リンク): URLリンク(kansai2channeler.hp.infoseek.co.jp)
①2次元平面上の点を表す構造体 Point 型を定義して,その点に関する計算を行うプログラムを作成したい.
以下のプログラムを基にして完成せよ.
構造体 Point型は,double型の X座標と Y座標のメンバをもつ.
構造体 Point型を使用して,原点からの距離を求める関数 length_vector_pを作成する.
ただし,「構造体ポインタ変数」を利用すること.
構造体 Point型を使用して,平面の点を表示する関数 print_v_pを作成する.
ただし,「構造体ポインタ変数」を利用すること.
②2次元平面上の点を表す構造体 Point 型を定義して,その点に関する計算を行うプログラムを作成したい.
以下のプログラムを基にして完成せよ.
構造体 Point型は,double型の X座標と Y座標のメンバをもつ.
構造体 Point型を使用して,平面の点を表示する関数 print_v_p2を作成する.
ただし,「構造体ポインタ変数」を利用すること.
構造体 Point型を使用して,平面の点を代入する関数 input_point_pを作成する.
ただし,「構造体ポインタ変数」を利用すること.
構造体ポインタ変数に対して,動的にメモリ領域を確保する. malloc を利用する.
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: visual stadio2008
 [3.3] 言語: C
[4] 期限: 2008年11月13日


611:デフォルトの名無しさん
08/11/11 21:21:25
>>607
前者でお願いします

612:デフォルトの名無しさん
08/11/11 21:25:52
>>600
とりあえず(1)
URLリンク(kansai2channeler.hp.infoseek.co.jp)

613:デフォルトの名無しさん
08/11/11 21:52:31
>>608
n 個の正数は a[] に入力されているとして。
#include <stdio.h>

int gcd(int x, int y)
{
int r;
if (x < y) {
int t = x; x = y; y = t;
}
do {
r = x % y; x = y; y = r;
} while (r != 0);
return x;
}

int main(int argc, char *argv[])
{
int a[] = { 121, 11, 14641, 1331};
int n = 4;
int i, g;

g = a[0];
printf("gcd(%d", a[0]);
for (i = 1; i < n; i++) {
printf(", %d", a[i]);
g = gcd(g, a[i]);
}
printf(") = %d\n", g);
return 0;
}

614:デフォルトの名無しさん
08/11/11 21:57:28
[1] 授業単元: 自作関数
[2] 問題文(含コード&リンク):

5つの数値を入力し(繰り返し入力)し、最大値を表示する。

[3] 環境
 [3.1] OS: Windowsvista
 [3.2] VC 6.0等
 [3.3] 言語: C

[4] 期限: 今日までなのでよろしくお願いします

[5] その他の制限:繰り返し文しかならってないです。

615:デフォルトの名無しさん
08/11/11 21:59:13
>>614

>>614

#include<stdio.h>
int sori(int x, int y)
{
if( x>=y ) return(x);
return(y);
}
int main(void)
{ int a,b,c,d,e,max;
while ( scanf("%d%d%d%d%d",&a,&b,&c,&d,&e)==5) {
max=a;
max=sori(max,b);
max=b;
max=sori(max,c);
max=c;
max=sori(max,d);
max=d;
max=sori(max,e);
printf("%d %d %d %d %d",a,b,c,d,e);
printf("max=%d\n",max);
}
return (0);
}


616:デフォルトの名無しさん
08/11/11 22:00:00
>>614
>>615
エラーメッセージ

エラー E2209 kadai6-1.cpp 1: インクルードファイル 'stdio.h' をオープンできない
エラー E2268 kadai6-1.cpp 9: 未定義の関数 'scanf' を呼び出した(関数 main() )
エラー E2268 kadai6-1.cpp 18: 未定義の関数 'printf' を呼び出した(関数 main()


上記のようなプログラムを自分で作ったのですが、
上に記したようなエラーメッセージが表示されてしまいました。
これ以上わかりません。どうかよろしくお願いします。




617:デフォルトの名無しさん
08/11/11 22:09:48
>>616
Linux  だとちゃんとコンパイルできるから、ワークスペース作ってないとかの問題じゃないの?

以下の行を削除すれば、一応目的は達成できるぞ
max=b;
max=c;
max=d;

618:デフォルトの名無しさん
08/11/11 22:17:17
>>617
試してみます。どうもありがとうございました。

619:デフォルトの名無しさん
08/11/11 22:23:31
コンパイルしたら
「配列または、ポインタでない変数に添字が使われました」って怒られたんですが
どう直せばいいでしょうか?


620:デフォルトの名無しさん
08/11/11 22:24:07
あきらめてください


621:デフォルトの名無しさん
08/11/11 22:25:41
配列またはポインタでない変数に、添え字を使わないようにすればいい

622:デフォルトの名無しさん
08/11/11 22:28:28
まずcppじゃなくてcにするとか


623:619
08/11/11 22:29:25
>>621
ありがとう!

624:デフォルトの名無しさん
08/11/11 22:30:24
てかsoriって関数名なんて意味?ソリ?サンタが乗ってるヤツ?

625:デフォルトの名無しさん
08/11/11 22:33:02
飲み過ぎ食べ過ぎに、ソリマックス。

626:604
08/11/11 22:36:08
>>604,605
素早い対応ありがとうございます。
すいません、問題文のとおりプログラムは1つだけなんです。
つまり、freqency.cを拡張して、横に伸びるグラフと縦に伸びるグラフを
同時に表示したいのです・・・。
605の方を別に作って試してみましたが、縦のグラフは表示できました。
(上の方で1つずつ空白分がずれるのは仕様でしょうか?)

604は、元のプログラムの出力部の変更のみで表示できました。
が、605と一緒にしなければならないので、どうにか605の大文字と小文字の処理を604と
同じくしてできないかと困っています。
よろしければ検討をお願いしたいです。

627:デフォルトの名無しさん
08/11/11 22:38:57
>>626
URLリンク(kansai2channeler.hp.infoseek.co.jp)
違う人だけど。

628:デフォルトの名無しさん
08/11/11 22:42:40
>>626
URLリンク(kansai2channeler.hp.infoseek.co.jp)

629:デフォルトの名無しさん
08/11/11 22:51:20
soriなんて名前付けてsorry・・・。

630:お願いします
08/11/11 23:23:42
[1] 授業単元: アルゴリズムデータ構造Ⅱ
[2] 問題文(含コード&リンク):
複素数a,bを標準入力から入力し、それぞれの絶対値を求め、2つの複素数の和、差、積、商を求め
標準出力に出力するプログラムを作りたい。これらを求める関数として、複素数の絶対値を求める関数
および和、差、積、商を求める関数が
double cabs(struct mycomplex)
struct mycomplex wa(struct mycomplex,struct mycomplex)
struct mycomplex sa(struct mycomplex,struct mycomplex)
struct mycomplex seki(struct mycomplex,struct mycomplex)
struct mycomplex shou(struct mycomplex,struct mycomplex)
として作ることにした。これらの絶対値、和、差、積と商を求める関数を解答せよ
なおこの構造体は予めCの処理系には用意されているが、それを利用せず独立に考えよ。
[3] 環境
 [3.1] OS: Windows
 [3.2]
 [3.3] 言語: C

[4] 期限: 11月16日まで

[5] その他の制限:構造体の問題です 問題文に沿ってお願いします。

631:604,626
08/11/11 23:23:58
>>627
一部重複箇所(横グラフが2つ出ました)がありましたので、それを修正した上で
実行したところ、結果が得られました。
>>628
こちらも正しい結果が得られました。

627さんのプログラムは使われた文字のみの出力、
628さんのプログラムは全てのアルファベットについての出力が確認できました。
もう一度しっかり目を通した上で使わせていただきたいと思います。

レスからわずか10分足らずでの迅速な対応、本当にありがとうございます。

632:お願いします
08/11/11 23:25:43
>>630
#include<stdio.h>
#include<math.h>
struct mycomplex {double re;
double im;};
int main()
{struct mycomplex a,b;
struct mycomplex wa(struct mycomplex,struct mycomplex);
struct mycomplex sa(struct mycomplex,struct mycomplex);
struct mycomplex seki(struct mycomplex,struct mycomplex);
struct mycomplex shou(struct mycomplex,struct mycomplex);
double cabs(struct mycomplex);
struct mycomplex cinput(void);
void cprint(struct mycomplex);
a=cinput(); b=cinput();
cprint(wa(a,b)); cprint(sa(a,b)); cprint(seki(a,b)); cprint(shou(a,b));
printf("絶対値 cabs(a)=%f\n",carbs(a)); printf("絶対値 cabs(b)=%f\n",cabs(b));}
struct mycomplex cinput(void)
{struct mycomplex z;
scanf("%f %f",&z.re,&z.im);
return z;}
void cprint(struct mycomplex z)
{ printf("複素数 = %f + i*%f\n",z.re,z.im);}

633:大輔
08/11/12 00:18:51
[1] 授業単元:繰り返し処理(for文・while文)
[2] 問題文(含コード&リンク):下に示すような九九の表を表示するプログラムを作成しなさい
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ名とバージョン:VC 6.0
 [3.3] 言語:C++
[4] 期限:2008年11月14日15:00まで
[5] その他の制限:printf,scanf,if,switch,程度の関数しか習っていません。for文の入れ子(二重のforループ)を使う。フォーマットをそろえるには、書式指定文字列(変換仕様)を利用。

   1 2 3 4 5 6 7 8 9
 1 1 2 3 4 5 6 7 8 9
 2 2 4 6 8 10 12 14 16 18
 3 3 6 9 12 15 18 21 24 27
 4 4 8 12 16 20 24 28 32 36
 5 5 10 15 20 25 30 35 40 45
 6 6 12 18 24 30 36 42 48 54
 7 7 14 21 28 35 42 49 56 63
 8 8 16 24 32 40 48 56 64 72
 9 9 18 27 36 45 54 63 72 81

634:デフォルトの名無しさん
08/11/12 00:26:39
>>633
#include <stdio.h>
main()
{
int i, j;
for(i = 0; i < 10; i++) {
for(j = 0; j < 10; j++)
if (i == 0)
if (j == 0)
printf(" ");
else
printf("%2d ", j);
else if (j == 0)
printf("%d ", i);
else
printf("%2d ", i * j);
printf("\n");
}
}


635:デフォルトの名無しさん
08/11/12 00:35:49
#include <stdio.h>

void main(){
 printf(" ");
 for(i=0; i<10; i++){
  printf(" %2d", i);
 }
 printf("\n");
 for(i=1; i<10; i++){
  printf("%d", i);
  for(j=0; j<10; j++){
   printf(" %2d", i*j)
  }
  printf("\n");
 }
}

636:634
08/11/12 00:37:47
>>635
こっちのほうがすっきりしてるね

637:デフォルトの名無しさん
08/11/12 00:39:11
↑jも1からだった

void main(){
 printf(" ");
 for(i=1; i<10; i++) printf(" %2d", i);
 printf("\n");
 for(i=1; i<10; i++){
  printf("%d", i);
  for(j=1; j<10; j++) printf(" %2d", i*j)
  printf("\n");
 }
}

638:デフォルトの名無しさん
08/11/12 00:41:40
%2dじゃ空白が入らないんじゃないの?

639:デフォルトの名無しさん
08/11/12 00:47:29
[1] 授業単元:プログラミング言語
[2] 改行を含む文字を受け取るにはどうすればいいんでしょうか?getを使えばスペースを含む文字を変数に書き込めるのは分かったんですが、改行を含む文字を書き込む方法が分かりません。

[3] 環境
 [3.1] OS: WindowsXP
 [3.2] コンパイラ名とバージョン: ごめんよく分からない。でも使っているのはMicrosoftからダウンロードしたVisual C++
 [3.3] 言語: C++
[4] 期限2008/11/15
[5] その他の制限: 無し

640:デフォルトの名無しさん
08/11/12 00:48:35
>>639
getsのこといってんだろうか・・・・・・・・
fgetsを使えばいんじゃね?

641:デフォルトの名無しさん
08/11/12 01:23:17
[1] 授業単元:ハッシュ法
[2] 問題文(含コード&リンク):指定したファイルを読み込み開放番地法でのハッシュ表を生成し、
  (i) 線形探査法
  (ii) 二重分散法
に基づいた探索関数を作成せよ。
(i),(ii)の探索関数を用いて任意の値
  (a) 表中に存在するキー      100個
  (b) 表中に存在しないキー     100個
について連続で探索し、総探査回数、総実行時間を記録する。(一部略)

[3] 環境
 [3.1] OS: Linux
 [3.2] gcc
 [3.3] 言語: C
[4] 期限: 11月12日21時迄


URLリンク(www1.axfc.net) (pass: jik1)
↑中身は問題原文、指定されたファイル、自分で作成したプログラムソースです
対象ファイルの中身が文字列なので探索にstrcmpを用いようとしたのですが、実行時にエラーが出てしまってどうすればいいかわからない状態です
よろしくお願いします

642:デフォルトの名無しさん
08/11/12 01:29:27
[1] 授業単元:アルゴリズム
[2] 問題文:5人の学生の3教科の点数(0~100点)をランダムに表示させる。
      それぞれの合計点を計算し、合計点の高い順に順位をつける。
[3] 環境
 [3.1] WindowsXP
 [3.2] gcc 3.4
 [3.3] C
[4] 期限:なし


どなたかおねがいします…orz

643:デフォルトの名無しさん
08/11/12 02:06:34
>>642
URLリンク(kansai2channeler.hp.infoseek.co.jp)

644:デフォルトの名無しさん
08/11/12 02:08:18
変数tmpはいらないから消してくれ

645:デフォルトの名無しさん
08/11/12 02:29:43
>>613
ありがとうございます
聞きたいんですが、a[]にn個の整数が入ってるとしてって所なんですけど、どうやって定義したんですか?

646:デフォルトの名無しさん
08/11/12 04:48:09
>>645
int a[] = { 121, 11, 14641, 1331};

647:デフォルトの名無しさん
08/11/12 05:36:33
1] 授業単元:プログラミング演習1 C言語の基礎
[2] 問題文(含コード&リンク):
 S=1+2+・・・n<100
を満たす最大の自然数nとSを出力するプログラムを作成してください。
for文とwhile文を用いたのをそれぞれ作成すること。
 考え方:ループを用いて1から順に自然数を足して行き、
和が100を段階で計算を打ち切るようにプログラムする

[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン: (gcc バージョンは最新
 [3.3] 言語: C
[4] 期限: 今日
[5] その他の制限:変数とハローワールドとscanf、条件文しかならってないはず

期限が近い・・・よろしくお願いします

648:デフォルトの名無しさん
08/11/12 06:06:08
>>647
#include <stdio.h>

main()
{
int S = 0, n;
for(n = 1; S + n < 100; n++){
S += n;
}
n--; // 足しすぎたので 1 引く
printf("n:%d S:%d\n", n, S);
S = 0;
n = 1;
while(S + n < 100){
S += n;
n++;
}
n--;
printf("n:%d S:%d\n", n, S);
}


649:デフォルトの名無しさん
08/11/12 06:14:44
>>648
なるほど・・・条件にS<100だから105しかでてこなかったのか俺・・・。
ありがとうございまいした、勉強になりました


650:デフォルトの名無しさん
08/11/12 08:00:09
[1] 授業単元:画像情報工学
[2] 問題文(含コード&リンク):
ブレゼンハムのアルゴリズムを用いて、ウインドウ内に線分を描画するプログラムを作成しなさい。
仕様1(マウスの左ボタンと右ボタンを使用する。候補線の表示は無し。)
マウスの左ボタンクリック    線分の始点座標の指定
マウスの右ボタンクリック    線分の終点座標の指定及び線分の描画

[3] 環境
 [3.1] OS:vista
 [3.2] コンパイラ名とバージョン:VC++ 2008
 [3.3] 言語: C
[4] 期限: 2008年11月12日まで
[5] その他の制限: ライブラリの点を描画するAPI関数を使って線分を引くこと。直線を引くAPI関数を使ってはならない。

Cは簡単なものしかやったことなくて全く分かりません
誰か助けてくださいお願いします……

651:デフォルトの名無しさん
08/11/12 08:16:50
誰か610お願いします

652:デフォルトの名無しさん
08/11/12 08:29:43
>>610

/* (x,y)-平面の点を座標で表す構造体 */
struct Point {
double x;
double y;
};
/* 原点からの長さを求める関数 */
double length_vector_p(struct Point *p)
{
return sqrt(p->x*p->x + p->y*p->y);
}
/* 平面の点を表示する関数 */
void print_v_p(struct Point *p)
{
printf("%f %f\n", p->x, p->y);
}
int main(void)
{
struct Point p;
printf("Input Point X: ");
scanf("%lf", &p.x);
printf("Input Point Y: ");
scanf("%lf", &p.y);
print_v_p(&p); /* print_v_pを使用して,座標の表示 */
printf("The length of vector: %f\n", length_vector_p(&p) );
return 0;
}


653:デフォルトの名無しさん
08/11/12 08:32:46
>>610
struct Point {
double x;
double y;
};
void input_point_p(struct Point *p){
printf("X:");
scanf("%lf", &p->x);
printf("Y:");
scanf("%lf", &p->y);
}
void print_v_p2(struct Point *p){
printf("%f %f\n", p->x, p->y);
}
int main(void){
struct Point *p; /* 構造体ポインタ変数 p */
int num, i;
printf("Input number of vector: ");
scanf("%d", &num);
for (i=0; i< num; i++) {
p = malloc(sizeof(struct Point)); /* malloc を使って領域確保 */
if( p == NULL ) {
printf( "memory cannot alloc!\n" );
exit( 1 );
}
input_point_p(p); /* 関数を使って要素を代入 */
print_v_p2(p); /* 関数を使って要素の表示 */
free(p); /* メモリの解放 */
}
return 0;
}

654:デフォルトの名無しさん
08/11/12 08:38:01
>650
期限は12日じゃなくて19日まででした……

655:デフォルトの名無しさん
08/11/12 10:13:51
>>646
ありがとうございます!

656:デフォルトの名無しさん
08/11/12 11:27:53
>>650
ライブラリって何の?
専用のをつかってるならそれもうp

657:デフォルトの名無しさん
08/11/12 13:21:11
期限が1日伸びたので>>491をお願いできませんか?

658:608
08/11/12 13:21:57
ちょっと聞きたいんですけど、学校から>>608に関係した問題が追加で出されたんだけど、それを解いてもらえることってできますか?

659:デフォルトの名無しさん
08/11/12 13:24:12
[1] 授業単元 プログラミング基礎
[2] 問題文(含コード&リンク)
  マイナスの値が入力されるまで繰り返し整数値を入力し最大、最小を求める。
  初期化で最大値には最小の値を、最小値には最大の値を設定しておく。
  繰り返しにはwhile文を使用する。
[3] 環境
[3.1] OS:Windows XP 
[3.2] コンパイラ名とバージョン: gcc
[3.3] 言語: C
[4] 期限: 2008年 11月14日 18時
[5] その他の制限: 特になし

  よろしくお願いします




660:デフォルトの名無しさん
08/11/12 13:40:57
>>656
渡されたプリントに書いてあったまんまなんで、自分でも良くわかりません……
授業ではC言語はおろかPCにすら触ってません

661:デフォルトの名無しさん
08/11/12 13:59:59
>>660
単に授業を聞いてなかったとかサボってたとかじゃなくて?
何の前説もなしにそのプリントをぽんと渡されただけなら行く学校を間違えたな
たぶん、説明はあったのに理解できなくてスルーしただけだろうけど

662:デフォルトの名無しさん
08/11/12 14:05:51
>>659
#include <stdio.h>

int main (void)
{
int n, min=32767, max=0;

while(1){
scanf("%d", &n);
if(n<0)
break;
if(n > max)
max = n;
if(n < min)
min = n;
}

printf("min = %d, max = %d\n", min, max);

return 0;
}

663:デフォルトの名無しさん
08/11/12 14:11:44
>>657
' ' とか '■' とか '○' マルチバイト文字を扱うのが面倒
' ' とか '*' とか 'o' でよかったらそんなにかからないけど

664:デフォルトの名無しさん
08/11/12 14:47:40
>>659
>>662 + 初期値可変入力

#include <stdio.h>
int main( void )
{
int i, n;
int imin, imax;
int nmin, nmax;
printf( "最小値の最大を入力してください>" );
scanf( "%d" , &imin ); /* 数値の入力 */
printf( "最大値の最小を入力してください>" );
scanf( "%d" , &imax ); /* 数値の入力 */

nmin=imin;
nmax=imax;
while (1) {
printf( "数値を入力してください>" );
scanf( "%d" , &n ); /* 数値の入力 */

if ( n < 0 ) /* 終了 */
{ printf( "終了\n" );break;}
if ( n < imin ) /* 最小値 */
{ nmin= n;}
if ( imax < n ) /* 最大値 */
{ nmax= n;}
}
printf(" 最小:%d\n", nmin);
printf(" 最大:%d\n", nmax);
}

665:デフォルトの名無しさん
08/11/12 14:54:11
>>661
授業が元々コンピュータでの画像の描画方法についてなんです
今までプログラムなんて一切なしでアルゴリズム?みたなのを学んでて
いきなりレポートの概要渡されました
授業は毎回出てますし、ノートも取ってます
それに居眠りとか出来る状況じゃないので
説明はあったんですが、それまでの知識じゃ全く理解できませんでした

666:デフォルトの名無しさん
08/11/12 15:03:29
どなたか>>641お願いできないでしょうか?
ヒントだけとかでもいいので・・・orz

667:デフォルトの名無しさん
08/11/12 15:39:48
>>646
調べたい整数の数を
を選べるようにするにはどうすればいいの?

668:639
08/11/12 15:46:44
>>640
あ、すいません。
getsの間違いでした。

fgets…使ってみたんですが、エラーが出ました。
今作っているソースは
#include<stdio.h>
#include<iostream>
#include<string>
using namespace std;
int main(){
char filename[20], time[100], data[1000000];
FILE *fp;
cout<<"CPUtime?"<<endl;
gets(time);
cout<<"data?"<<endl;
gets(data);
fp = fopen("file.txt","w");
fprintf(fp,"%s\n",time);
fprintf(fp,"%s",data);
fclose(fp);
}
で、本当は「file.txt」ってなってるファイル名を、キーボードから受け取るようにして(filenameとは宣言したものの…)
dataに、
「 0 1.99400005840289e-007 -1.99400005840289e-007 9.89100023673223e-014 2.63400000595493e-012
1e-011 1.99400005840289e-007 -1.99400005840289e-007 9.89000006022811e-014 2.63400000595493e-012
2e-011 1.99400005840289e-007 -1.99400005840289e-007 9.89100023673223e-014 2.63400000595493e-012
4.000015229e-011 1.99400005840289e-007 -1.99400005840289e-007 9.89299991211411e-014 2.63400000595493e-012
…」みたいな改行を含んだ文字をコピーして実行画面(コマンドプロンプト)に貼り付けてテキストファイルを作りたいんですがよく分かりません。

669:デフォルトの名無しさん
08/11/12 15:48:54
>>667
調べたい整数をユーザに入力させたい、ってとこか?
それならこんなかんじ。

int main(int argc, char *argv[])
{
int *a;
int n, i, g;

printf("調べたい整数の数は?: ");
scanf("%d", &n);
a = malloc(n * sizeof(int));
for (i = 0; i < n; i++) {
printf("%d 個目の整数を入力してください: ", i+1);
scanf("%d", &a[i]);
}

g = a[0];
--- >>613 と同様 --
free(a);
return 0;
}

670:デフォルトの名無しさん
08/11/12 16:01:12
>>612
解答あり

>>600の(2)できる方おねがいします

671:デフォルトの名無しさん
08/11/12 16:10:20
>>663
それでお願いできますか?

672:デフォルトの名無しさん
08/11/12 16:14:23
>>665
理解できなかったのならなぜ質問しなかったのだろう?
その感じだと実際に動作するコードを書くのではなく
アルゴリズムや疑似コードをレポートにして提出しろってことなのか?

673:デフォルトの名無しさん
08/11/12 16:19:45
>>668
余計なお世話だけど、 time って関数があるから time という変数名は避けたほうがいいかも。

fp = fopen("file.txt", "w");
fprintf(fp, "%s\n", time);
while (fgets(data, sizeof(data), stdin) != NULL) {
fprintf(fp, "%s", data);
}
fclose(fp);

とすれば、Ctrl-D を入力するまで読み取り続けます

674:デフォルトの名無しさん
08/11/12 16:21:11
>>671
よく考えたら、表示のときだけマルチバイト文字使って、内部データは
普通の int とか char とか好きなので行けるわ
もう一点確認だけど、どっちからどっちに球が飛んでいけばいいの?

675:デフォルトの名無しさん
08/11/12 16:22:19
生活安全課のボツボツキモデブ●創価●警官名言集www
「俺の脅迫のおかげで家から出れなくした。俺の手柄だ!」
「昼間は市役所のパトロール隊を使う。夜は消防団を使う。」
「●指導●じゃない、パトロールを●お願い●してるだけだ。人権侵害行為は俺の責任じゃない!」

熊本隆談www

676:デフォルトの名無しさん
08/11/12 16:23:34
>>669

: In function ‘main’:
:22: 警告: incompatible implicit declaration of built-in function ‘malloc’
:24:8: 警告: 不明なエスケープシーケンス '\$'


だそうです

677:デフォルトの名無しさん
08/11/12 16:29:14
>>676
#include <stdlib.h> を追加。
それから
a = (int *)malloc(n * sizeof(int));
と、キャストしたほうがいいかも。
下のは知らん。日本語の文字列が正しく読まれてないのかもしれない。
適当に文字列を半角英数字のみにしてみて。

678:デフォルトの名無しさん
08/11/12 16:36:38
テスト中orz
1.から100までの整数で3の倍数の整数の合計を求めるプログラムをFor文を利用して作ってください。
2.1の問題をForの変わりにWhile文で頼みます。

余裕があれば、
3.タクシー料金:最初の2kmまで650円 以後400mごとに90円としたとき、乗車距離(km)を入力し、
料金求める。
おねがいします。

679:デフォルトの名無しさん
08/11/12 16:41:59
>>678
テストぐらい自分でやれ!

680:デフォルトの名無しさん
08/11/12 16:42:11
>>816
/*1.*/
#include <stdio.h>
int main(void){
int i, sum = 0;
for(i = 1; i <= 100; i++){
if (i % 3 == 0) sum += i;
}
printf("合計は %d\n", sum);
}
/*2.*/
#include <stdio.h>
int main(void){
int i = 1, sum = 0;
while(i <= 100){
if (i % 3 == 0) sum += i;
i++;
}
printf("合計は %d\n", sum);
}
/*3.*/
#include <stdio.h>
int main(void){
double kyori;
int ryokin;
printf("乗車距離(km): ");
scanf("%lf", &kyori);
if (kyori < 2) ryokin = 650;
else ryokin = 650 + (kyori / 400) * 90;
printf("料金は %d円です。\n", ryokin);
}

681:639
08/11/12 16:43:13
>>673
ありがとう!ありがとう!改行文字も出来ました。
でもCtrl-Dを入力せずに、貼り付けた文字の最後まで行ったら自動で終了するのは出来ないんでしょうか?
>>668に書いた数値データ、何百行もあるのですが、最後の行まで読み込んだら終了させたいです。

682:デフォルトの名無しさん
08/11/12 16:59:53
>>667
出来ました!
マジでありがとうございます

683:デフォルトの名無しさん
08/11/12 17:02:22
>>681
何をもって読み込みを終了するかが決められないからムリかな。
>>673 のコードでは、EOF (Ctrl-D) をもって終了としてるから、たとえば
echo "cputime\ndata1\ndata2" | ./a.out
などとすることは可能。

しかし一体何をしたいんだ?
その数値データはテキストファイルに保存されてるの?
それなら CPUtime だけを入力して、数値データはそのテキストファイルから読み取ればいいわけだけど。

684:デフォルトの名無しさん
08/11/12 17:09:50
>>680
ラスト10min
ありがとう。たすかりました。

685:639
08/11/12 17:14:19
>>683
<<しかし一体何をしたいんだ?
これ、大学の数値実験で出た何百行もの値(SPICEっていう電気回路のCADツールを使って出た値)で、この数値をコピーして、gnuplotでグラフを書きたいんだ。
①SPICEからデータ(数値)をコピーして取り出す。
②テキストファイルに貼り付ける。
③作成したテキストファイルからgnuplotでグラフを描く。
この一連の作業をプログラムで作りたかったんだ…。
一応数値データも要るので、gnuplotに直接書き込んで終了という訳にもいかず、テキストファイルも残したいんです。

686:デフォルトの名無しさん
08/11/12 17:29:19
すみませんがどなたか>>584をやって頂けないでしょうか頂けないでしょうか。
>>586さんのいうとおりisalphaとtoupperを使えばいいのはわかっているんですが、
どうやってそれをソースに書きかえればいいのかまったくわからないので困っています。
今日が締切なのでお願いします。

687:デフォルトの名無しさん
08/11/12 17:44:51
>>587です
亀ですが>>592の方ありがとうございました
嫌いと言いながらやってくれる優しさに惚れた
また明日結果報告させて頂きます

688:デフォルトの名無しさん
08/11/12 17:46:37
宿題でお聞きしたいのですが…問題は以下のようなものです。

「直行座標系X-Yにより定められている平面上で、0 < X,Y < 1の正方領域をX,Y方向にそれぞれ(n1 - 1)個、(n2 - 1)個に等分割して、その座標を出力する。」

自分で、以下のようなプログラムを作ってみました。

#include<stdio.h>
#define n1 7
#define n2 7

int main(){
double X[n1], Y[n2];
int i, j;

for(i = 0; i < n1; i++){
*(X + i) = ((1 / (n1 - 1)) * (double)i);
}
for(i = 0; i < n2; i++){
*(Y + i) = ((1 / (n2 - 1)) * (double)j);
}

for(i = 0; i < n1; i++){
for(j = 0; j < n2; j++){
printf("(%lf, %lf) ", *(X + i), *(Y + j));
}
printf("\n");
}
}

すると、(0.0000000, 0.0000000)の座標で埋め尽くされてしまいました…
玄人の皆様、お助け下さい…

689:デフォルトの名無しさん
08/11/12 17:53:04
>>688
double にキャストする位置がおかしい。

- *(X + i) = ((1 / (n1 - 1)) * (double)i);
+ *(X + i) = (1.0 / (n1 - 1)) * i;

Y も同様。

690:デフォルトの名無しさん
08/11/12 17:53:46
>>688
1/(n1 -1) ← 分母分子ともに整数だと、整数の除算が行われるから
1.0/(n1 - 1) とか 1/(n1 - 1.0) とか、どっか double にしないと暗黙の型変換は起こらない

あと

*(Y + i) = ((1 / (n2 - 1)) * (double)j); ← i でループ回してるんだkら (double)j じゃなくて i だな

691:デフォルトの名無しさん
08/11/12 18:08:49
>>689,>>690
どうもありがとうございます、そういうことなのですか(^^;
皆さんに教わらなければ、多分あと2日くらいは悩んでたと思います。

また質問させて頂く時もあるかと思いますので、その時はまたよろしくお願いします。


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