C/C++の宿題片付けま ..
[2ch|▼Menu]
357:307の間違い
09/05/27 19:14:21
>>307(9255) Vector勉強になった。 それとついでに>>324(9269) >>(9271) N-Queenを解くプログラム
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <time.h>
using namespace std;
struct student {
  string name;
  int score;
};
bool operator<(const student& x, const student& y) {
  return x.score < y.score;
}
int main(void) {
  int i;
  char buf[50];
  student s, t;
  vector<student> vecStudent;
vector<student>::iterator theIterator;
  srand((unsigned)time(0));
  for(i=0; i<20; i++) {
    sprintf(buf, "名前.%02d.名前", i+1); s.name = buf; s.score = rand() % 101;
    vecStudent.push_back(s);
  }
for (theIterator = vecStudent.begin(); theIterator != vecStudent.end(); theIterator++)
    cout << theIterator->name << ":" << theIterator->score << endl;
  cout<<endl; sort(vecStudent.begin(), vecStudent.end());
  for(i=0; i<20; i++)
    t = vecStudent[i], cout<<t.name<<":"<<t.score<<endl;
  return 0;
}

358:デフォルトの名無しさん
09/05/27 20:04:04
>>354-356
どのような構造体かわからなかったので妄想してコーディングした。
URLリンク(kansai2channeler.hp.infoseek.co.jp)
兄ぃそこはらめぇー、とか。あぁ、酔ってるわ。

359:デフォルトの名無しさん
09/05/27 20:32:00
>>358
ありがとうございます。
でもコメントが文字化けしていて
どんな処理をしているのかわかりませんでしたorz

構造体は
struct A a{
struct B *front_p;
struct B *back_p;
int list_sum;
}

struct B b{
char *str_p;
struct B *next_p
}
です。
書き忘れすみません。
よろしくお願いします。

360:デフォルトの名無しさん
09/05/27 20:43:14
>>358
構造体は予想どおりだったか。

コメントの文字化けは知らんがな。
UTF-8だから、nkfかiconvでSJISにでもしてみてね。
それか、サクラエディタかnotepad++で読み込むとか。

私の考えでは、別にリストのポインタを入れ替えていく必要はないと。
つまり、文字列(char *)だけ入れ替えてやるだけで済むと。
ソートしたい対象が文字列(char *)なのにリストのポインタを替えていくなんて無駄な処理でしょ。
だから、文字列(char *)だけソートしたものが>>358なのよ。

361:307の間違い
09/05/27 20:44:16
>でもコメントが文字化けしていて
>どんな処理をしているのかわかりませんでしたorz
(9273)右クリックでファイルをダウンロードすれば読めるはず。
URLリンク(kansai2channeler.hp.infoseek.co.jp)

362:デフォルトの名無しさん
09/05/27 21:11:55
>>360
文字列のみの入れ替えは完成していたのですが、
講師からリスト自体を入れ替えろと言われました…。

あとコメント見れました。

363:デフォルトの名無しさん
09/05/27 22:35:50
[1] 授業単元:C言語
[2] 問題文(含コード&リンク):URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: Linux
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: [2009年06月03日24:00まで]
[5] その他の制限: 特になし。
よろしくお願いします

364:デフォルトの名無しさん
09/05/28 00:25:36
[1] 授業単元:
[2] 問題文(含コード&リンク):1!〜53!を計算して、それらを右揃えで出力するプログラムを
                  作成せよ
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: Visual C++
 [3.3] 言語: C言語
[4] 期限: [2009年6月2日17:00まで]
[5] その他の制限:・プログラムを幾つかの関数に分割する
URLリンク(kansai2channeler.hp.infoseek.co.jp)
↑途中まで作ったのですが空白にしたいところが0で埋まってしまって困っています。
よろしくお願いします


365:デフォルトの名無しさん
09/05/28 00:25:55
>>363
具体的にどこがわからんの?

366:デフォルトの名無しさん
09/05/28 00:39:17
>>364

print関数だけ。


void print(int a[],int N,int n)
{
    int i;
    int head;
        
    printf("%2d! = ",n);

    head = 0;
    for(i=N-1; i>=0; i--) {
        if (head)
            printf("%07d",a[i]);
        else if (a[i]) {
            printf("%7d",a[i]);
            head = 1;
        }
        else
            printf("       ");
    }
    printf("\n");
}

367:デフォルトの名無しさん
09/05/28 00:45:29
[1] 授業単元:プログラム演習
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: windows
 [3.2] コンパイラ名とバージョン: visual c++
 [3.3] 言語: C++
[4] 期限: 朝までに。すごく困っています
[5] その他の制限: 特になし
よろしくお願いします


368:デフォルトの名無しさん
09/05/28 00:52:30
>>366
ありがとうございます。
0は消えたんですが右揃えになりません。


369:デフォルトの名無しさん
09/05/28 00:56:08
>>366
すいません。なりました。本当にありがとうございました

370:デフォルトの名無しさん
09/05/28 01:01:49
>>367
greater()をstructの後に移動
if(a.point>b.point)

371:デフォルトの名無しさん
09/05/28 01:05:09
[1] 授業単元:C言語
[2] 問題文(含コード&リンク):線形検索を使用して配列内の最大の要素を検索せよ。
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:来週火曜日
[5] その他の制限:制限はありません
まずアルゴリズムが全く思いつきません。
よろしくお願いします。

372:デフォルトの名無しさん
09/05/28 01:06:17
>>370

ありがとうございました。
昨日から悩んでいたのがやっと解決しました

373:デフォルトの名無しさん
09/05/28 01:19:43
[1] 授業単元:プログラム演習
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: windows
 [3.2] コンパイラ名とバージョン: Visual C++
 [3.3] 言語: C++
[4] 期限:できるだけ早く

お願いします

374:デフォルトの名無しさん
09/05/28 01:39:22
[1] 授業単元:情報処理
[2] 問題文(含コード&リンク):
(1)1からn番目までの奇数2n-1までの和をn=1からn=50まで求め、n,和(sum),
n~2の値を出力せよ。また、プログラムの中でsum=0;およびn--;が
 必要な理由を答えよ。
(2)原点を中心とした半径2の円を描くプログラムを作成せよ。
[3] 環境
 [3.1] OS:XP
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:今週金曜日
[5] (2)についての条件
  @半径2の値はconst型で初期化しておき、実数型とする。
  A円の方程式は平面極座標(r,φ)を用いてforループでφを0から
  2πまで変化させてガウス座標(x,y)を出力する。
  Bforループの制御変数はint型とする。
長くなってしまいすいません。よろしくお願いいたします。


375:デフォルトの名無しさん
09/05/28 01:46:08
[1] 授業単元: 最適化
[2] 問題文(含コード&リンク):
URLリンク(kansai2channeler.hp.infoseek.co.jp)
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: Visual C++
 [3.3] 言語: C++
[4] 期限: 5月30日
ランダム関数を使うらしいのですが全く分かりません。
よろしくお願いします。

376:デフォルトの名無しさん
09/05/28 02:10:13
>>373
URLリンク(kansai2channeler.hp.infoseek.co.jp)

377:デフォルトの名無しさん
09/05/28 02:36:04
>>371
URLリンク(kansai2channeler.hp.infoseek.co.jp)

378:デフォルトの名無しさん
09/05/28 02:37:09
[1] 授業単元: 情報処理入門
[2] 問題文(含コード&リンク):
   キーボードから実数 x を入力し、ニュートン法と呼ばれる次のような反
復の式を用いて、近似的に x の平方根を求めるプログラムを作成せよ。
--
 xの平方根は、次の計算を| s(i+1)-s(i) | < ε, i=1,2,...となるまで繰
り返すことによって求めることができる。εは収束判定数である。

  s(i+1) = ( s(i) + x / s(i)) / 2
ただし、s(1) = 1 とする。
 なお、ε=0.00001として計算すること。

[3] 環境
 [3.1] OS: WindowsXP
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 2009年5月29日00:00まで
[5] その他の制限: なし

よろしくお願いします。


379:デフォルトの名無しさん
09/05/28 02:50:29
>>371
URLリンク(kansai2channeler.hp.infoseek.co.jp)

380:デフォルトの名無しさん
09/05/28 06:16:47
>>364
void print(int a[],int N,int n) {
int i;
printf("%2d! = ",n);
for(i=N-1; i>=0&&a[i]==0; i--) printf("%7c",' ');
printf("%7d",a[i]);
for(i--; i>=0; i--) printf("%07d",a[i]);
printf("\n");
}

381:243
09/05/28 06:36:52
>>245 246
先週は助けていただき有難うございました。
関連する問題になるのですが、以前複素数のクラスを作成しました。
URLリンク(kansai2channeler.hp.infoseek.co.jp)

このクラスもPass_Betterを使って値渡しにするよう言われたのですが、
どなたか分かる方いたらお願いします。
[1] 授業単元: C++
[2] 問題文(含コード&リンク):
[3] 環境
 [3.1] OS: Windows
 [3.2] コンパイラ名とバージョン: Visual C++
 [3.3] 言語: C++
[4] 期限: 5月30日

382:デフォルトの名無しさん
09/05/28 09:26:42
>>374
問題文(1)の中の「n~2の値」、何を出力すればいい?

383:sage
09/05/28 10:11:18
[1] 授業単元:C言語
[2] 問題文(含コード&リンク):番兵を利用して配列内の最大の要素を検索するプログラムを作りなさい
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C言語
[4] 期限:6月2日
[5] その他の制限:制限はありません
お願いします

384:デフォルトの名無しさん
09/05/28 10:34:58
指数関数e^xの近似値を返す関数expon(x, n)をつくります。第1引数は浮動小数点数xで,第2引数はexをTaylor展開で展開する際の最大次数nになります。n次項までのTaylor展開の式は下に示す通りです。
さらに,浮動小数点数yと正の整数mを引数とし,yの小数点m桁より下を切り捨てて出力する関数trunc(y, m)をつくりなさい。
次に,これらの2つの関数を用いて,e^xの近似値を小数点以下の桁数を指定して出力するプログラムをつくりなさい。
[1] 授業単元:C言語
[2] 問題文(含コード&リンク):
指数関数e^xの近似値を返す関数expon(x, n)をつくります。第1引数は浮動小数点数xで,第2引数はexをTaylor展開で展開する際の最大次数nになります。n次項までのTaylor展開の式は下に示す通りです。
さらに,浮動小数点数yと正の整数mを引数とし,yの小数点m桁より下を切り捨てて出力する関数trunc(y, m)をつくりなさい。
次に,これらの2つの関数を用いて,e^xの近似値を小数点以下の桁数を指定して出力するプログラムをつくりなさい
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:5月30日
[5] その他の制限:なし

385:デフォルトの名無しさん
09/05/28 10:39:59
すいません>>384はミスです。

[1] 授業単元:C言語
[2] 問題文(含コード&リンク):
指数関数e^xの近似値を返す関数expon(x, n)をつくります。第1引数は浮動小数点数xで,第2引数はexをTaylor展開で展開する際の最大次数nになります。n次項までのTaylor展開の式は下に示す通りです。
さらに,浮動小数点数yと正の整数mを引数とし,yの小数点m桁より下を切り捨てて出力する関数trunc(y, m)をつくりなさい。
次に,これらの2つの関数を用いて,e^xの近似値を小数点以下の桁数を指定して出力するプログラムをつくりなさい
関数truncは,trunc(-3.141593, 3) と呼び出すと,-3.141のように画面に出力する。但し,printf("%.*f", m, y); は用いないで定義すること。
[3] 環境
 [3.1] OS:Linux
 [3.2] コンパイラ名とバージョン:gcc
 [3.3] 言語:C
[4] 期限:5月30日
[5] その他の制限:なし


386:デフォルトの名無しさん
09/05/28 10:55:54
[1] 授業単元: ソフトウエア科学
[2] 問題文(含コード&リンク):

 4桁の10進数の各桁を千の位からd3,d2,d1,d0で表すと、
((d3*10+d2)*10+d1)*10+d0という計算をすることにより、元の10進数を得ることができる。
4桁の10進数の各桁を、まず、大きさ4のint型配列に1桁ずつに入力し、
その後、上記の計算法により、元の10進数にして表示するプログラムを書け。
ただし、上記の計算部分はfor文による繰り返しにより記述すること。

例;入力が4536ならば、((4*10+5)*10+3)*10+6=4536の計算をして表示する。

  
[3] 環境
 [3.1] OS:Windows
 [3.2] コンパイラ名とバージョン: gcc
 [3.3] 言語: C
[4] 期限: 2009年5月29日12:50まで
[5] その他の制限:特になし

お願いします。


387:デフォルトの名無しさん
09/05/28 11:17:17
>>386
URLリンク(kansai2channeler.hp.infoseek.co.jp)

表示周り適当に修正してちょ

388:デフォルトの名無しさん
09/05/28 11:27:02
>>387
ありがとうございました。

389:デフォルトの名無しさん
09/05/28 11:47:24
もうちょっと面白い問題プリーズ


390:デフォルトの名無しさん
09/05/28 12:09:18
>>380
ありがとうございます

391:デフォルトの名無しさん
09/05/28 12:10:02
>>389
オナニーは楽しいかい?

392:デフォルトの名無しさん
09/05/28 14:13:57
>>389
Windowsのフリーセルの最小手順検索はいかが?
ここで最小手順とは人間が操作を行う回数のこと
列移動も一回として数える

393:デフォルトの名無しさん
09/05/28 14:40:16
>>365さん
入力した内容を暗号化(置き換え)してファイルに保存する方法が分からないです
よろしくお願いします

394:joyful_age
09/05/28 14:44:16
>>363 (Ex-1) Data input by menu.
URLリンク(kansai2channeler.hp.infoseek.co.jp)

395:joyful_age
09/05/28 15:04:34
>>363 修正。ID、名前の数字は置換しない。
void angouka(char *s) {
   for(; *s != '\0'; s++)
     if(*s < '0' || *s > '9') (*s)++;
}

396:デフォルトの名無しさん
09/05/28 15:14:18
>>389
難易度が高くて未回答の問題が幾つもあるだろ。解いてみろ。


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

5337日前に更新/150 KB
担当:undef