[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 2chのread.cgiへ]
Update time : 01/02 08:46 / Filesize : 251 KB / Number-of Response : 871
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

計算アルゴリズム【U】



153 名前:デフォルトの名無しさん mailto:sage [2005/11/13(日) 18:28:11 ]
>>147
入力の仕様がわからなかったので,以下の仕様に従うことにした.標準入力から読み込む.
「1行目: 都市の数,2行目から: 都市1 都市2 その間の距離,終端: EOF」

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
const int inf = 1 << 30;
// brute force using recursion ( O(n!) )
int solve(int pos, int start, vector< vector<int> >& adj, vector<bool>& used) {
  used[pos] = true;
  int d = inf; 
  if (find(used.begin(), used.end(), false) == used.end()) d = adj[pos][start];
  for (int i = 0; i < used.size(); ++i) 
    if (!used[i]) d = min(d, adj[pos][i] + solve(i, start, adj, used));
  used[pos] = false;
  return d;
}
int main() {
  int n; cin >> n;
  vector< vector<int> > adj(n, vector<int>(n, inf));
  int a, b, d;
  while (cin >> a >> b >> d) adj[a][b] = adj[b][a] = d;
  vector<bool> used(n, false);
  int start = 0; used[start] = true;
  cout << solve(start, start, adj, used) << endl;
}






[ 続きを読む ] / [ 携帯版 ]

全部読む 前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<251KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef