C/C++の宿題を片付け ..
[2ch|▼Menu]
129:デフォルトの名無しさん
08/07/15 13:06:33
>>1
【アップローダー==ラウンジ】(質問が長い時はココ使うと便利 回答者もコードが長ければここに)
URLリンク(kansai2channeler.hp.infoseek.co.jp)

130:115
08/07/15 13:09:11
ああ、すまん

131:デフォルトの名無しさん
08/07/15 13:15:43
>>55

void del_chr(char *str, char c){
char *s,*d;
s = d = str;

do{
if(*s != c) *d++ = *s;
}while(*s++);
}


132:131
08/07/15 13:17:07
かぶった。
リロードしてなかったorz

133:デフォルトの名無しさん
08/07/15 13:17:46
>>120
別の学校で同じ課題が出たのかな。
先生も課題考えるのめどいんだろうなー

134:115
08/07/15 13:18:56
>>133
実は先生も課題用として動く物をこのすれの住人に作らせてると
俺は常々思ってる。

135:デフォルトの名無しさん
08/07/15 13:20:54
そんな先生がいたらちょっとした質問であたふたしそうだw

136:デフォルトの名無しさん
08/07/15 13:23:12
>>125,131
ありがとうございます

…そっか、do文か

137:デフォルトの名無しさん
08/07/15 13:27:14
>>134
う〜〜ん・・・同じ学校の別の生徒と思われるかもしれんが、もしかすると
講師が課題作りをしたは良いが、模範解答をどうしようか考えて
ここを利用している可能性もあるかもね・・・その構図を思い浮かべて、
ちょっとワラタw っつか、俺利用されたっ!?

138:デフォルトの名無しさん
08/07/15 13:28:35
学生臭いスレですね

139:デフォルトの名無しさん
08/07/15 13:29:56
>>131
うおっ、その手があったか。先にレスしたけど、それパクらせてもらうw

140:115
08/07/15 13:31:37
現実にそれっぽいのがあったんだよ。

週末にここで質問された内容が週明けに再度復活とかさ・・・・

141:デフォルトの名無しさん
08/07/15 13:33:36
>>35
スレリンク(tech板:723番)
スレリンク(tech板:725番)
スレリンク(tech板:757番)
スレリンク(tech板:760番)


142:デフォルトの名無しさん
08/07/15 13:35:09
>>140
なるほど、確かに。講師が模範解答の依頼、それを次の授業の後に
ここで質問した人が、既出のソースをそのまま提出して
お前、あのスレを使ったな?っとバレて単位がもらえないなんて
ことが、どこかの学校であるかも・・・そんな構図を思い浮かべて
ますます吹いたw

143:デフォルトの名無しさん
08/07/15 13:37:52
>>141 のソースに、2 2 0 と入力した場合について指摘がされているが
それをどう解釈するか?確かにこの場合、2番目も1番目も同じと
解釈するなら、2でも問題なし。まぁ、同じでも偶数は2つ入力されている
わけだから、これでも問題の趣旨としては条件を満たしていると思われる。

144:デフォルトの名無しさん
08/07/15 13:41:31
学生だって土日は外で遊ぶこともあるべ

145:デフォルトの名無しさん
08/07/15 13:52:55
[1] 授業単元: C++
[2] 問題文(含コード&リンク):
次の説明を読んで、プログラムを作成しなさい。

小数で入力される気温のデータを5℃単位の整数に丸めたい。
キーボードからdouble型変数kに気温を入力し、
丸めた数値はint型変数gに求め、gを画面に出力する。

ただし入力データに負の気温はないものとする。

また必要なら、
計算途中の中間結果を格納するint型変数wなど、
適宜変数を用意すること。
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン:VC
 [3.3] 言語: C++
[4] 期限:
[5] その他の制限: 繰り返しや分岐を使わず、簡単な計算で

146:デフォルトの名無しさん
08/07/15 13:53:54
[1] 授業単元: C++
[2] 問題文(含コード&リンク):
キーボードから100点満点のテストの点数を入力し(-1で終了)、
10点ごとの人数を int型の配列 count[11]に数えるプログラムを
作成せよ。 テストは100点満点とし、それ以外の入力はエラーとし
て無視する。ただし -1 はデータの終了を表すものとする。 点数
の入力が終了したら、度数分布を画面に出力して終了する。出力は
人数と,*(アスタリスク)によるグラフとする。
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン:VC
 [3.3] 言語: C++
[4] 期限:
[5] その他の制限:

147:デフォルトの名無しさん
08/07/15 13:54:37
>>128
ありがとうございます!無事鳴りました。
自機も移動する時鳴らしたいのですが、同じようにやるんですか?

148:デフォルトの名無しさん
08/07/15 13:55:09
[1] 授業単元: C++
[2] 問題文(含コード&リンク):
次の処理を行うプログラムを作成し実行結果を確認しなさい。

int型の配列a[5]、int型へのポインタp1, p2を宣言する
配列名aで表示される値を画面に出力する
配列a[5]のすべての要素のアドレスを出力する
ポインタp1にa[0]のアドレス、ポインタp2にa[4]のアドレスを格納する
p1 - p2を計算し出力する
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン:VC
 [3.3] 言語: C++
[4] 期限:
[5] その他の制限:
3問」ありますが、よろしくお願いします。

149:115
08/07/15 14:17:45
URLリンク(kansai2channeler.hp.infoseek.co.jp)


150:115
08/07/15 14:18:16
>>149>>147

151:115
08/07/15 14:27:29
すまん、フラグを立てる際間違えてた

if(key_lt == HOLD_KEY || key_rt == HOLD_KEY) {
if( tx >= 0 && tx + cw <= 640){
px = tx;
soundflg1 = 1;
} else {
soundflg2 = 1;
}
}
if(key_up == HOLD_KEY || key_dn == HOLD_KEY) {
if( ty >= 0 && ty + ch <= 480){
py = ty;
soundflg1 = 1;
} else {
soundflg2 = 1;
}
}

152:デフォルトの名無しさん
08/07/15 14:33:36
[1] 授業単元: C言語プログラミング
[2] 分数の四則演算を計算するプログラムを作成する
[3] 環境
[3.1] OS: Windows 
[3.3] 言語・C++
[4] 期限: ([2008年7月21日14:00まで
[5]条件
  分数を、 1|3 のように、| (縦棒)という記号で分子・分母を区別する。/ (スラッシュ)だと除算記号と混同してしまうから。
計算規則
 a|b + c|d = (a*d + b*c) | (b*d)
 a|b - c|d = (a*d - b*c) | (b*d)
 a|b * c|d = (a*c) | (b*d)
 a|b / c|d = (a*d) | (b*c)
計算結果については,分母が1の時には分子のみの表示にする。分数が0(ゼロ)の時には 0(ゼロ)のみを表示する。また,最終の計算結果を既約分数にする。

1.分母がゼロの入力エラーに対しては、再入力するよう促す。

2.除算において、除数がゼロの入力エラーに対しては、再入力するように促す。

3.以下範囲の整数(分子、分母にかかわらず)に対して、正しく計算できるようにすること。
  -2147483648 〜 2147483647



153:115
08/07/15 14:42:15
でキー押しっぱなしだとうるせーよ対策バージョンはこれ

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

154:デフォルトの名無しさん
08/07/15 14:45:19
>>115
やさしいね

155:デフォルトの名無しさん
08/07/15 14:46:32
>>154
こういう題材じゃなければぶっちしてるw

156:デフォルトの名無しさん
08/07/15 15:13:59
>>153
ありがとうございます!できました。
最後に今までのをユーザー関数群でまとめたいのですが、
どうすれば良いでしょう?

157:115
08/07/15 15:18:03
うーん

クラスになってるからユーザー関数にするような箇所がないかも?

大半の機能はelライブラリでやってるし・・・

C++得意な方よろしこorz

158:デフォルトの名無しさん
08/07/15 15:23:14
>>156
一度自分で完成させたソースを上げて、見てもらったほうがいいよ。


159:デフォルトの名無しさん
08/07/15 15:33:00
[1] 授業単元:
C
[2] 問題文(含コード&リンク):()
URLリンク(kansai2channeler.hp.infoseek.co.jp)
URLリンク(kansai2channeler.hp.infoseek.co.jp)
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: (Windows/Linux/等々)
Windows
 [3.2] コンパイラ名とバージョン: (gcc 3.4 VC 6.0等)
Microsoft Visual Studio 2008
 [3.3] 言語: (C/C++/どちらでも可 のいずれか)
C
[4] 期限: ([yyyy年mm月dd日hh:mmまで] または [無期限] のいずれか)
明日
[5] その他の制限: (どこまで習っているか、標準ライブラリは使ってはいけない等々)
基本ソートのcity.txtは問題文の一番下です。
お願いします。


160:デフォルトの名無しさん
08/07/15 15:35:53
>>158
分かりました。

その前に自機と敵を下のに変えるには、
どこをどのように変更すれば良いのですか?

自機
URLリンク(www.dotup.org)


URLリンク(www.dotup.org)

今までのソース
URLリンク(www.dotup.org)

161:デフォルトの名無しさん
08/07/15 15:36:46
>>35 Thanks, Part112>>760
#include <stdio.h>

int main(void) {
  int m1=0, m2=0, n;

  while( scanf("%d",&n) ) {
    if(n == 0) break;
    if(n%2 == 1) continue;
/*
 * if(n==m1) continue;
 * if(n >m2) m2=n;
 * if(m1<m2) swap(&m1, &m2); */
    if(n>m2) {
      if(n>m1) { m2=m1; m1=n;}
      else if(n==m1) ;
      else m2=n;
    }
  }
  printf("%d \n",m2);
  return 0;
}

162:デフォルトの名無しさん
08/07/15 15:39:39
>>145

#include <iostream>

int main(void){
double k;
int g;

std::cout << "気温を入力:";
std::cin >> k;
g = k / 2.5;
g += g % 2;
g = g / 2 * 5;
std::cout << "気温は約" << g << "℃です。" << std::endl;
return 0;
}


163:115
08/07/15 15:42:52
>>160
その敵のほうのさ、白いのっていまどきマスクパターンっていわないよねw

あくまで敵が何か発動中はその白塗りになると思っていいよね?

164:デフォルトの名無しさん
08/07/15 15:47:31
>>163
はい。そうです。

165:デフォルトの名無しさん
08/07/15 15:48:50
>>163
跳ね返りの時、白く点滅できれば…。

166:デフォルトの名無しさん
08/07/15 15:52:06
>>35
URLリンク(kansai2channeler.hp.infoseek.co.jp)
指摘のあった、一番大きい値が2回入力された場合に対処してみた。

167:デフォルトの名無しさん
08/07/15 15:58:04
>>152
適当に
URLリンク(kansai2channeler.hp.infoseek.co.jp)

168:161
08/07/15 16:01:52
scanf の戻り値はエラーなら0か-1

169:58
08/07/15 16:04:08
すみません
どなたか>>58をお願いできませんか?

170:デフォルトの名無しさん
08/07/15 16:07:23
>>146
#include <iostream>

int main(void){
int count[11];
int n;

for(int i = 0;i < 11;i++) count[i] = 0;
while(1){
std::cout << "点数入力:";
std::cin >> n;
if(n == -1) break;
if(0 <= n && n <= 100) count[n/10]++;
}
for(int i = 0;i < 10;i++){
std::cout << std::endl << i * 10 << "〜" << i * 10 + 9 << "(" << count[i] << "名)\t|";
while(count[i]-- > 0) std::cout << "*";
}
std::cout << std::endl << "100(" << count[10] << "名)\t|";
while(count[10]-- > 0) std::cout << "*";

return 0;
}


171:デフォルトの名無しさん
08/07/15 16:09:06
>>148
#include <iostream>

int main(void){
int a[5],*p1,*p2;

std::cout << "a=" << a << std::endl;
for(int i = 0;i < 5;i++){
std::cout << "a[" << i << "]のアドレス:" << &a[i] << std::endl;
}
p1 = &a[0];
p2 = &a[4];
std::cout << "p1 - p2 (&a[0] - &a[4]) = " << p1 - p2 << std::endl;

return 0;
}


172:115
08/07/15 17:04:35
>>163
URLリンク(kansai2channeler.hp.infoseek.co.jp)


173:115
08/07/15 17:05:06
>>163じゃねえ>>165

174:デフォルトの名無しさん
08/07/15 17:10:56
[1] 授業単元:プログラミング第一
[2] 問題文(含コード&リンク):
構造体bintree_nodeを次のように定義する。
typedef struct bintree_node{
int value;
struct bintree_node *lt,*rt;
} *bintree;
このとき、次の条件を満たす関数void delgraph(bintree t)を作成せよ。
・tからたどることのできる節点をすべてfreeによって消去する
・tに合流点・ループがあっても必ず停止し、かつどの節点にもfreeが2回以上適用されないようにする
[3] 環境
 [3.1] OS: (Windows/Linux/等々)
Windows
 [3.2] コンパイラ名とバージョン: (gcc 3.4 VC 6.0等)
gcc
 [3.3] 言語: (C/C++/どちらでも可 のいずれか)
C
[4] 期限: ([yyyy年mm月dd日hh:mmまで] または [無期限] のいずれか)
7/16 12:00
[5] その他の制限: (どこまで習っているか、標準ライブラリは使ってはいけない等々)
以前、似たような問題をこちらで聞いた時のプログラム(木構造に合流点やループがないかどうか調べる)
URLリンク(kansai2channeler.hp.infoseek.co.jp)
に付け足していただけるとうれしいです。

175:デフォルトの名無しさん
08/07/15 17:11:05
PlayerChara(60,660
この数字がおかしいな



176:デフォルトの名無しさん
08/07/15 17:42:27
>>89
m(dz^2/dt^2)-an/h(dz/dt)-kz=0

177:デフォルトの名無しさん
08/07/15 17:48:23
>>100ですが、
回答はご用意頂けたでしょうか?

178:デフォルトの名無しさん
08/07/15 18:00:38
>>174
その元のコードだとbintreeはmallocを使わず実装してるので
この課題には流用しずらい。

それに付け足すまでもなく自明に実装できる。
void delgraph(bintree tree){
static bintree_node dummy;
if(!tree || tree->lt == &dummy)return;
bintree lt = tree->lt,rt=tree->rt;
tree->lt = &dummy;
delgraph(lt);
delgraph(rt);
free(tree);
}
ようするに一度巡回したノードにはltにdummy突っ込んでおくだけ。
削除するんだから値を勝手に書き換えても問題ないだろう。

179:デフォルトの名無しさん
08/07/15 18:17:51
0の値が格納された整数変数 pos_area を使って bst_sorted_output(root,A,&pos_area)を実行することにより、
2分探索木に格納されている整数データを配列Aへ小さい順に整列して出力する関数bst_sorted_output(Node *node, int A, int *pos)をC言語を用いてコーティングせよ。
ただし、変数*pos(実体はpos_area)は配列Aにおける次の格納位置を示すのに使うものとする。

180:デフォルトの名無しさん
08/07/15 18:20:21
>>177
#include<stdio.h>
#include<stdlib.h>
int fib(int i){
static int count;
int answer;
if(i==0){ int ret=count;count=0;return ret; }
if(i <=2){ return 1;}
answer = fib(i-1) + fib(i-2); // 3回加算
count+=4; // 1回加算 計4回
return answer;
}
int fib2(int i){
static int count;
int n, fib_n_0=1, fib_n_1=1, fib_n_2=1;
if(i==0){ int ret=count;count=0;return ret; }
for(n=3;n<=i;n++){ // 1回加算
fib_n_2=fib_n_1+fib_n_0; // 1回加算
fib_n_0=fib_n_1;
fib_n_1=fib_n_2;
count+=3; // 1回加算 計3回
}
return fib_n_2;
}
int main(int argc, char *argv[]){
int fib_n=20;
printf("%d ", fib(fib_n));
printf(" %d\n", fib(0));
printf("%d ", fib2(fib_n));
printf(" %d\n", fib2(0));
return 0;
}

181:174
08/07/15 18:52:33
>>178
回答ありがとうございます。
いただいたのをもとにプログラムを書いてみたんですが、うまく削除できてないみたいなんです・・・
URLリンク(kansai2channeler.hp.infoseek.co.jp)
これを実行すると@を5回表示するんですが、bintree 〜 is deleted.のほうは表示されなくて。
申し訳ありませんがもう1度見ていただけますか。

182:デフォルトの名無しさん
08/07/15 18:56:27
>>181
削除は出来ている。
ただ、ローカル変数のta0とかの値は削除したからって自動でNULLにならない。
単にbintree 〜 is deleted.の部分のif文がおかしいだけ。

183:174
08/07/15 19:10:38
>>181
調べてみたら、確かにfreeした後の領域はNULLではなくて、
何があるかわからないということが書いてありました。
そうすると、削除したかどうかってどうやって調べればいいんでしょう・・・。

184:デフォルトの名無しさん
08/07/15 19:13:47
>>35 なのですが、関数を使わずにか、
#include <stdio.h>
void swap(int *a, int *b) {
int c;
c=*a; *a=*b; *b=c;
}
int main() {
int max1 = 0, max2 = 0, num;
while(scanf("%d", &num) == 1){
if(num == 0) break;
if(num < 0 || num % 2 == 1) continue;
if(num > max2) max2 = num;
if(max1 < max2) swap(&max1, &max2);
}
printf("%d\n", max2);
return 0;
}
*aやcontinue、&max1を使わずに出来ないでしょうか?
何度も申し訳ありません。

185:デフォルトの名無しさん
08/07/15 19:18:37
>>184
このスレ内に汝の欲するものは既にある

186:デフォルトの名無しさん
08/07/15 19:19:55
空白文字の個数を保ったまま、文字列を単語単位で処理をしたいんですが
どのように記述するのが良いのでしょうか

例えば次の文字列があり、単語の先頭にあるaだけ大文字にしたいです

_aba__dea__aga__   (_は空白)
_Aba__dea__Aga__   (こうなってほしい)

stringstreamでパースして、後で結合する方法を思いつきましたが、この方法だと空白は消えてしまいました。
地道に1文字ずつみて、str[i]==0 || (str[i-1]==' ' && str[i]!=' ')
こういった判定をする以外に良い方法ってありますか?

187:デフォルトの名無しさん
08/07/15 19:24:39
UDP:相手先のオンライン、着信確認をせずに送ること
TCP:相手先がオンラインであること、着信確認を取った上で送ること
という理解でいいでしょうか?

188:デフォルトの名無しさん
08/07/15 19:31:55
>>186
こういうことをしたいのかな?
それともaだけを大文字にするのかな?
#include<iostream>
#include<string>
#include<cctype>

int main(void){
std::string foo=" aba dea aga ";

std::cout << foo << std::endl;
for(int i=0,next_toupper_flag=1;i<foo.size();i++){
if(next_toupper_flag) foo[i]=toupper(foo[i]); // 書き換えてるけどこれっておk?
if(isspace(foo[i])) next_toupper_flag=1;
else next_toupper_flag=0;
}
std::cout << foo << std::endl;
}

189:デフォルトの名無しさん
08/07/15 19:37:21
>>186
while (*str)
{
while (*str == ' ') str++;
if (*str == 0) break;
else if (*str == 'a') *str = 'A';
while (*str && *str != ' ') str++;
}


190:デフォルトの名無しさん
08/07/15 19:37:29
うpローダー使おうよ

191:デフォルトの名無しさん
08/07/15 19:49:53
複数レスにならない限り過去ログに残るほうがうれしい
質問者側としては検索で出てくるのはまずいかもしれないが…

変数名変えれば多分大丈夫さw

192:デフォルトの名無しさん
08/07/15 19:51:40
[1] 授業単元:C言語
[2] 問題文 URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: Windowsxp
 [3.2] コンパイラ名とバージョン: VC 6.0
 [3.3] 言語: C
[4] 期限:7月18日

お願いします

193:デフォルトの名無しさん
08/07/15 20:05:21
>>192
URLリンク(kansai2channeler.hp.infoseek.co.jp)


194:デフォルトの名無しさん
08/07/15 20:06:24
すいませんがお願いします。

[1] 授業単元: Cプログラミング演習
[2] 問題文(含コード&リンク)

以下のようなdouble型配列がある。配列の全要素の合計と平均を求める
プログラムをポインタを使用して作成しなさい。

[配列の定義]
double date[5]={10.8,20.3,30.6,40.4,50.5}

[実行結果]

配列の内容
date[]=10.800000,20.300000,30.600000,40.400000,50.500000
合計=152.600000
平均=30.520000

[3] 環境
 [3.1] OS: (Windows vista)
 [3.2] コンパイラ名とバージョン: (visual studio 2005 )
 [3.3] 言語: (C言語)
[4] 期限:今週いっぱいまで
[5] その他の制限: (シンプルにおねがいします)


195:デフォルトの名無しさん
08/07/15 20:07:51
>>193どうもです!!

196:デフォルトの名無しさん
08/07/15 20:35:23
>>194
#include<stdio.h>
#include<stdlib.h>
int main(int argc, char *argv[]){
double date[5]={10.8,20.3,30.6,40.4,50.5}, *p=date, sum, ave;
int i;

printf("date[]=%.6f", sum=*p++);
for(i=1;i<5;i++,p++){
printf(",%.6f", *p);
sum+=*p;
}
ave=sum/5;
printf("\n合計=%.6f\n", sum);
printf("平均=%.6f\n", ave);
return 0;
}

197:デフォルトの名無しさん
08/07/15 20:36:13
>>184
やっぱりわからないです…



198:デフォルトの名無しさん
08/07/15 20:47:23
[1] 授業単元: Cプログラミング
[2] 問題文:URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:Linux
 [3.2] gcc 
[3.3] 言語:C
[4] 期限:7月17日

お願いします。

199:194
08/07/15 20:48:48
>>196
すごい、完璧に動きました。
ありがとうございます!

200:デフォルトの名無しさん
08/07/15 20:50:55
完璧に動く > 完動 > 感動した!

201:デフォルトの名無しさん
08/07/15 21:06:53
>>194 シンプル >
#include <stdio.h>

#define COUNT 5
double date[5]={10.8,20.3,30.6,40.4,50.5};

void main(void)
{
  int i;
  double *p=date, sum=0.0, ave;

  printf(" 配列の内容\n date[]=");
  for(i=0; i<COUNT; i++, p++) {
    sum += *p;
    printf("%f", *p);
    if(i < COUNT-1) printf(",");
  }
  ave = sum / COUNT;
  printf("\n 合計=%f\n 平均=%f\n", sum, ave);
}

202:デフォルトの名無しさん
08/07/15 21:09:30
[1] 授業単元:プログラミング
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS:windowsXP
 [3.2] コンパイラ名とバージョン:VC6.0
 [3.3] 言語: C++
[4] 期限: 至急
[5] その他の制限:問題文をソースの上に載せています。よろしくおねがいします


203:デフォルトの名無しさん
08/07/15 21:09:34
>>198
URLリンク(kansai2channeler.hp.infoseek.co.jp)

204:デフォルトの名無しさん
08/07/15 21:11:27
動作は完璧かもしれないが、出題内容のdateはdataに変えるべきだと思った。

205:デフォルトの名無しさん
08/07/15 21:12:53
>>198
URLリンク(kansai2channeler.hp.infoseek.co.jp)

206:デフォルトの名無しさん
08/07/15 21:20:39
どうか>>50をお願いします!!

207:デフォルトの名無しさん
08/07/15 21:21:22
[1] 授業単元:数値計算
[2] 問題文(含コード&リンク):
y' = x +y
y(0) = 0
の厳密解を求めるプログラムを作って☆
[3] 環境
 [3.1] OS:mac os x leopard
 [3.2] コンパイラ名とバージョン:gcc.4.0.1
 [3.3] 言語: C
[4] 期限: 至急
[5] その他の制限:printfもfprintfもしなくて結構です。ええ、そうです。私ができないのは積分なのです…orz

すいませんすいませんすいませんすいませんすいません…。公式分かってるけど、計算ミスが多すぎて何が何だかなのです><

208:186
08/07/15 21:26:37
>>188
ありがとうございます。
next_toupper_flagで単語の先頭(書き換えるべき箇所)を保持してるわけですね
書き換えもOKだったので助かりました。

>>189
ポインタ苦手なんですが、何とか理解できました。
最初、全てのaを置換しているのかと思いましたが
最後のwhileで先頭以外を読み飛ばしてるんですね


209:デフォルトの名無しさん
08/07/15 21:41:29
>>184ですが
関数使わずにか* & continueを使わない方法ないですか?
図々しいとは思いますが、今日中なので頼みます

210:デフォルトの名無しさん
08/07/15 21:46:25
>>209
>>166 でダメなら諦めるしかない

211:デフォルトの名無しさん
08/07/15 21:55:52
>>107
>>110
Zako[0] = new Chara(200, 80,"bmp/teki.bmp", 1,NULL,3, 0, 0,5, 2,40,40);
にすればいいだけなのに(´;ω;`)

>>126
引数4は

0-背景
1- パターン1 → パターン2 → …… → パターンN → パターン1→ ……
2- パターン1 → パターン2 → …… → パターンN → パターンN-1 → パターンN-2 → …… → パターン1 → ……

212:デフォルトの名無しさん
08/07/15 21:58:06
>>210
アドバイスありがとうございます。


213:198
08/07/15 22:02:15
>>205
ありがとうございます!
初めて見る単語の理解に努めます・・・

214:デフォルトの名無しさん
08/07/15 22:12:06
[1] 授業単元: Cプログラミング演習
[2] 問題文
20次元の2つのベクトル余弦cos(θ)を求めよ。
ベクトルの要素はそれぞれ、ユーザーが入力すること。ベクトル要素は
double型とすること。


[3] 環境
 [3.1] OS: (Windows vista)
 [3.2] コンパイラ名とバージョン: Linux
 [3.3] 言語: (C言語)
[4] 期限:7/16
[5] その他の制限: 特になし


215:デフォルトの名無しさん
08/07/15 22:42:36
>>4 07/15 13:00 線形リスト
>>17 07/15 14:00 分数の四則演算を計算するプログラム
>>35 07/15 17:00 キーボード入力と表示 : >>72, >>141, >>161, >>166
>>37 07/15 17:00 数字の読み方 : >>39, >>40, >>42?
>>44 07/17 --:-- 4択3種
>>45 07/15 07:00 ゲーム? : >>108->110 その他アドバイスは多数
>>46 07/18 --:-- メディアン : >>47, >>49
>>50 07/17 00:00 減衰振動
>>51 07/15 12:00 ソーティング:基本交換法と挿入法 : >>91
>>55 07/15 14:00 文字列中の特定文字を削除 : >>125, >>131
>>58 07/15 18:00 木構造を用いた数式の処理
>>84 07/16 12:30 自由落下・BMI : >>86

216:デフォルトの名無しさん
08/07/15 22:44:03
>>100 07/17 --:-- フェボナチ数列 : >>180
>>145 --/-- --:-- 5ごとに丸め >>162
>>146 --/-- --:-- 数字入力と度数分布表示 : >>170
>>148 --/-- --:-- ポインタ演算 : >>171
>>152 07/21 14:00 = >>17 : >>167
>>159 07/16 --:-- 複素数演算・ソーティング
>>174 07/16 12:00 領域開放 : >>178?
>>179 --/-- --:-- 2文木->配列
>>186? : >>188, >>189

217:デフォルトの名無しさん
08/07/15 22:44:33
>>192 07/18 --:-- ? : >>193
>>194 07/18 --:-- 配列の全要素の合計と平均 : >>196, >>201
>>198 07/17 --:-- 大文字小文字3題 : >>203, >>206
>>202 --/-- --:-- (ごめんなさい、よくわからないです。)
>>207 --/-- --:-- 微分方程式の解析解
>>214 07/16 --:-- 20次元の2つのベクトル余弦

218:84
08/07/15 22:45:01
>>86
ありがとうございます!
まさかこんなに早く答えていただけるとは・・・助かりました。
見たことある単語がいくつもあったので自分にも理解できそうです。

219:デフォルトの名無しさん
08/07/15 22:49:39
>>214 20次元の場合の計算方法はこれでいいのか?
#include<stdio.h>
#include<math.h>
#define EPS (1.0e-20)
typedef struct tag_vector20d_t{
double num[20];
}vector20d_t;
double vector20d_size(const vector20d_t *vector20d){
int i; double x2=0.0;
for(i=0;i<20;i++) x2+=vector20d->num[i]*vector20d->num[i];
return sqrt(x2);
}
double vector20d_inner_product(const vector20d_t *a, const vector20d_t *b){
int i; double ret=0.0;
for(i=0;i<20;i++) ret+=a->num[i]*b->num[i];
return ret;
}
double vector20d_cos(const vector20d_t *a, const vector20d_t *b){
double size_a, size_b;
size_a=vector20d_size(a);
size_b=vector20d_size(b);
if(size_a<EPS || size_b<EPS) return -10.0;
return vector20d_inner_product(a, b)/(size_a*size_b);
}
int main(void){
int i; vector20d_t a, b;
for(i=0;i<20;i++) scanf("%lf", &(a.num[i]));
for(i=0;i<20;i++) scanf("%lf", &(b.num[i]));
printf(" %f\n", vector20d_cos(&a, &b));
return 0;
}

220:デフォルトの名無しさん
08/07/15 23:09:22
>>100
ありがとは?

>>596
過去ログ嫁

221:デフォルトの名無しさん
08/07/15 23:13:59
>>201
ループの中に無駄な分岐を入れるのはバカ

222:デフォルトの名無しさん
08/07/15 23:16:34
>>221
どのくらい早くなりますか?

223:174
08/07/15 23:27:22
追記です。
URLリンク(kansai2channeler.hp.infoseek.co.jp)
でta1のltをta4にしたとき(合流点があるとき)、@を1つ出力したあとAbortedと出て強制終了してしまいます。
(↑ta4をfreeしたあとta3でta4にアクセスしようとするから?)
他にも、ta3のrtをta2にするとSegmentation Errorとなってしまいます。
ループのときは正しく動いているようなので、上の2つのようなときに正しく動けばいいんですが・・・
よろしくお願いします。(引き続き>>183も答えていただけると幸いです)

224:デフォルトの名無しさん
08/07/15 23:27:27
>>201
このばあいほとんど分岐が起こらないから、きにする必要なし。

225:デフォルトの名無しさん
08/07/15 23:39:35
分岐結果の分布がどうとかではなくて毎回判定処理が動作することを懸念してるんで無いの?
今回の場合は大差ないし、そういうのは必要に応じてやればいいと思うけど。

226:デフォルトの名無しさん
08/07/15 23:45:30
なんでもループにまとめたり、短く書くことがいいことだと思う時期があんだよな。

227:デフォルトの名無しさん
08/07/16 00:14:21
>>223
あーそれは俺のバグだなぁ。
たしかにfreeを実行するタイミングが早すぎた。
修正してみた。あんまり自明なアルゴリズムじゃなくなってしょんぼり。
void delgraph2(bintree tree,bintree*rest){
static bintree_node dummy;
if(tree && tree->lt != &dummy)
{
bintree lt = tree->lt , rt = tree->rt;
tree->lt = &dummy;
tree->rt = *rest;
*rest = tree;
delgraph2(lt,rest);
delgraph2(rt,rest);
}
}
void delgraph(bintree tree){
bintree rest = NULL;
delgraph2(tree,&rest);
while(rest){
bintree self=rest;
rest = rest->rt;
free(self);
}
}


228:デフォルトの名無しさん
08/07/16 00:18:00

[1] 授業単元: Cプログラミング演習
[2] 問題文
#include<stdio.h>
#include<string.h>

main()
{char string[]= "I write the book about internet search engine.";
printf("%s",string);
}


string内の配列内の文字列の順番を逆にせよ。ただし出力だけが逆文字
に表示されては駄目である。配列の中身自体を変えなければいけない

[3] 環境
 [3.1] OS: (Windows vista)
 [3.2] コンパイラ名とバージョン: Linux
 [3.3] 言語: (C言語)
[4] 期限:7/16
[5] その他の制限: 特になし


229:デフォルトの名無しさん
08/07/16 00:23:19
#include <stdio.h>

int main(void)
{
char string[] = "I write the book about internet search engine.", *p, *q, temp;

printf("%s\n", string);

for(p=string; *p; p++);
q = string;
while(p-- > q) {
temp = *p;
*p = *q;
*q++ = temp;
}

printf("%s\n", string);

return 0;
}

230:デフォルトの名無しさん
08/07/16 00:25:13
>>228 過去ログ
URLリンク(kansai2channeler.hp.infoseek.co.jp)

231:デフォルトの名無しさん
08/07/16 00:27:38
[1] 授業単元:プログラム実習
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: windows xp
 [3.2] コンパイラ名とバージョン:vc6.0
 [3.3] 言語: C++
[4] 期限: 早急に…
[5] その他の制限:
配列の問題です よろしくおねがいします



232:デフォルトの名無しさん
08/07/16 00:33:58
>>231
すまないが、配列の配列は動的に確保できないんじゃよ。We apologize for your inconvenience...

233:デフォルトの名無しさん
08/07/16 00:40:22
>>231
>>28 URLリンク(kansai2channeler.hp.infoseek.co.jp)

234:デフォルトの名無しさん
08/07/16 01:24:02
[1] 授業単元:数値解析
[2] 問題文(含コード&リンク):減衰振動の運動方程式
m(d^2x/dt^2)=−kx−α(dx/dt) をルンゲクッタ法で解くやり方を教えてください
m k αはキーボードからの入力値です 初期条件はx(0)=0 , x'(0)=0です
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: VC 6.0
 [3.3] 言語: C
[4] 期限: >>50でしましたが、とりあえずこれだけわかればなんとかできそうなんで・・・

235:デフォルトの名無しさん
08/07/16 01:56:00
>>234
ルンゲクッタ法とか法がつくものは、やり方のことだよ。
明日朝以降にもう一度お願いすれば、もしかしたら
誰かが解いてくれてるかも

236:デフォルトの名無しさん
08/07/16 02:02:46
>>235
解くまでもなく
0しか答えがないので釣りとみなされました。

237:デフォルトの名無しさん
08/07/16 02:16:12
[1] 授業単元:
[2] 問題文(含コード&リンク):ランダムに現れる#、$、%、&を同じ記号で3つ揃えるスロットゲームの作成
  条件:スロットをするかどうかをy、nで判定
     スロットを行う
     実行結果通りの結果を出力させる
[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C言語
[4] 期限: 至急
[5] その他の制限:実行結果の例
         スロットをを回しますか?(y/n)>>>y
         幸運をお祈りします
         ###
         大当たり
         スロットを回しますか?(y/n)>>>n
         ありがとうございました

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

238:44
08/07/16 02:31:44
だれか>>44の問題お願いします

239:デフォルトの名無しさん
08/07/16 03:35:38
>>44,238
1.1 [A] struct xyz [B] struct xyz [C] {0,0,0} [D] t
1.2 [A] struct xyz * [B] (*x).x [C] (*x).y[D] (*x).z
2.1 typedef struct tDate{ int y,m,d }Date;
2.2 void printDate(Date d) { fprintf( stdout, "%4d/%2d/%2d", d.y,d.m,d.d ); }
2.3
void printDateGen(Date d)
{
#define DD(Y,M,D) ((Y)*10000+(M)*100+(D))
char *Era[] = {"","明治","大正","昭和","平成"};
int y, e, dd = DD(d.y,d.m,d.d);
e = ( dd >= DD(1989,1,8) ) ? 4 : ( dd >= DD(1926,12,25) ) ? 3 : ( dd >= DD(1912,7,30) ) ? 2 : ( dd >= DD(1868,9,8) ) ? 1 : 0;
y = d.y - ( ( e == 1 ) ? 1867 : ( e == 2 ) ? 1911 : ( e == 3 ) ? 1925 : ( e == 4 ) ? 1988 : 0 );
if ( y == 1 ) { fprintf( stdout, "%s 元年 %2d月 %2d日", Era[e], d.m, d.d ); }
else { fprintf( stdout, "%s %2d年 %2d月 %2d日", Era[e], y, d.m, d.d ); }
}


240:237
08/07/16 03:44:28
>>>237
誰かお願いします 切羽詰ってます

241:デフォルトの名無しさん
08/07/16 04:17:34
>>240
「至急」なんて書かれても、「その内やる」としか思わないんじゃね?

242:237
08/07/16 04:24:04
>>>237
午前7時まで

243:デフォルトの名無しさん
08/07/16 04:41:34
>>240 >>237
URLリンク(kansai2channeler.hp.infoseek.co.jp)
スペースキーを押すと、左から順に止めることが出来る仕様

244:デフォルトの名無しさん
08/07/16 04:42:30
あぁ、すまん、繰り返すかの y/n は自分で適当に組み込んでおいて

245:237
08/07/16 04:59:02
>>>244
ありがとうございます!
繰り返すのはfor文ですよね?

246:デフォルトの名無しさん
08/07/16 05:11:44
うむ。やっぱ、もう少し書き直してみるんでお待ちを

247:デフォルトの名無しさん
08/07/16 05:20:46
>>240 >>237
URLリンク(kansai2channeler.hp.infoseek.co.jp)
これでどうかな?

248:デフォルトの名無しさん
08/07/16 08:01:50
>>234
とりあえず解いてみてください

ちなみにこれであってる?
一般解の形は x(t)=a*e^(-b*t*i)+c 但し e をネイピア数、i を虚数単位とする

249:デフォルトの名無しさん
08/07/16 08:15:52
>>202
コンパイルエラーを取る問題。無理なのでネタと判断した。

250:デフォルトの名無しさん
08/07/16 08:16:29
[1] 授業単元: Cプログラミング演習
[2] 問題文
構造体配列struct tfield name[10];がありメンバにchar str1;があるとします
文字列を適当にabscedと標準入力したとして
その文字列を1文字ずつ構造体配列name[i].str1にいれるように.
最終的にそのname[i].str1を表示するブログラムを
[3] 環境
 [3.1] OS: LINUX
 [3.3] 言語: (C言語)
[4] 期限:7/16
[5] その他の制限: 特になし



251:248
08/07/16 08:21:46
>>248 の一般解、定数 b が複素数かも
よーわからん

忘却の彼方なので数学部分は中学レベルまでにして

252:デフォルトの名無しさん
08/07/16 08:32:55
>>250
文字列の終端はどうするの?
#include<stdio.h>

struct tfield{
char str1;
};

int main(void){
struct tfield name[10];
char buf[10+1]="";
int i;

fgets(buf, sizeof(buf), stdin);
for(i=0;buf[i];i++) name[i].str1=buf[i];
// for(i=0;name[i].str1=buf[i];i++);
for(i=0;i<10;i++) printf("%c\n", name[i].str1);

return 0;
}

253:249
08/07/16 08:51:07
void (*a)(const strtype) = show;
void (*b)(const strtype&) = show;

a(hello);
b(hello);

254:デフォルトの名無しさん
08/07/16 10:14:17
キーボードから50人分の点数を入力し
90点以上の人の番号と点数を表示せよ。

っていうプログラムってどんな感じですか?

255:デフォルトの名無しさん
08/07/16 10:17:58
入力が大変です

256:デフォルトの名無しさん
08/07/16 10:19:34
[1] 授業単元: Cプログラミング演習
[2] 問題文
キーボードから50人分の点数を入力して、90点以上の人の番号と点数を表示せよ
[3] 環境
 [3.1] OS: vista
 [3.3] 言語: (C言語)
[4] 期限:
[5] その他の制限: 特になし

257:デフォルトの名無しさん
08/07/16 10:53:56
>>254
50人分の点数をテキストファイルにでも保存して
リダイレクトを使えば、プログラムを実行してから
毎回入力する手間は省けるが。
あとは、受け継いだ点数から90以上のものをカウントする
プログラムを作ればええがな。

258:デフォルトの名無しさん
08/07/16 10:57:34
あ、カウントじゃなくて番号と点数で良いのか。
まぁ、そういうことで、1行ずつ先頭から番号、点数、改行して
50人分の点数を記述するか、点数も乱数を使って発生させるのもありやな。
ってことで、誰かやってちょっ。自分はちと席を外すんで。

259:デフォルトの名無しさん
08/07/16 11:14:17
>>256
リダイレクト使った成績入力は自分でやってくれ

#include <stdio.h>

#define CLASSMAX (2) /* クラスの人数 */
#define MAXNAME (128) /* 名前の最大文字数 */
#define BOADER_POINT (90) /* 表示する最低点数 */

/* 生徒1分の成績 */
typedef struct tagRECORD {
char name[MAXNAME];
int point;
} RECORD;

void input_record(RECORD *r, int i)
{
const int MAXBUF = 128;
char buf[MAXBUF];

printf("Name[%d]?:", i);
scanf("%s", r->name);
printf("Point[%d]?:", i);
scanf("%d", &(r->point));
}

void print_record(RECORD *r)
{
printf("Name: %s, Point: %d\n", r->name, r->point);
}


260:デフォルトの名無しさん
08/07/16 11:14:58
>>259 続き

int main(int argc, char *argv[])
{
RECORD clsRecord[CLASSMAX];
int i;

/* クラスの成績を入力 */
for (i = 0; i < CLASSMAX; i++) {
input_record(&clsRecord[i], i);
}

/* BOADER_POINT以上の生徒の成績表示 */
printf("\n***** Over %d students *****\n", BOADER_POINT);
for (i = 0; i < CLASSMAX; i++) {
if (clsRecord[i].point >= BOADER_POINT) {
print_record(&clsRecord[i]);
}
}

return 0;
}

261:デフォルトの名無しさん
08/07/16 11:17:38
// 入力フォーマット: [番号],[得点]

int main()
{
  int i;
  int number;
  int score;

  for ( i = 0; i < 50; i++ ) {
    scanf( "%d,%d", &number, &score);
    if ( score >= 90 ) {
      printf("%d,%d", number, score);
    }
  }
}

262:デフォルトの名無しさん
08/07/16 11:39:01
アンカー忘れてる、は回答プレ?

263:デフォルトの名無しさん
08/07/16 12:56:07
[1] 授業単元:プログラミング演習
[2] 問題文(含コード&リンク):
#include<stdio.h>

main()
{
char ch;

while(scanf("%c", &ch)==1){
ch-=0x20;
printf("%c", ch);
}
}

上記のプログラムを改良し、アルファベットは大文字と小文字を逆転し、それ以外の文字はそのまま表示するようにしなさい。
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:?
 [3.3] 言語:C
[4] 期限:[本日16:30まで]

宜しくお願いします。


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

4688日前に更新/131 KB
担当:undef