読者です 読者をやめる 読者になる 読者になる

Tamflexの貯蔵庫

やる気のない備忘録

codeIQ 2717

dfsで全探索する. int n; vector<int> a; int dfs(int k, int sum) { if(k==a.size()) return sum; int x = dfs(k+1,sum+a[k]); int y = dfs(k+1,sum); return abs(n-x)<abs(n-y)? x : y; } int main() { int t; cin >> n; while(cin >> t) a.push_back(t); sort(a.begin(),a.end()); cout << abs(n-dfs(0,0)) <</abs(n-y)?></int>…

codeIQ 2791

codeiq.jp例によってdfsとメモ再帰で解けます. struct P { int x; int y; P(){}; P(int x,int y):x(x),y(y){}; P operator+(const P&q){P t;t.x=x+q.x;t.y=y+q.y;return t;} P operator+=(const P&q){x+=q.x;y+=q.y;return *this;} bool operator!=(const P&…

c++11でグラフ理論

競プロで頻繁にグラフが絡む問題が出題されます. 隣接リストvector<vector<Edge>>を継承してグラフの様々な値を求めることができるクラスを作ってみました. 使い方 ・宣言 graph<T> g((int)n): 重みの型がTの,頂点の数がn個の隣接グラフの宣言. ・辺の挿入 g.direct(src,dst,</t></vector<edge>…

abc 036

d問題 abc036.contest.atcoder.jpdfsとメモ再帰化でできる…はずだったのにlonglongとintを使い間違えて無事終了 #include <bits/stdc++.h> #define SIZE 300005 #define MOD 1000000007LL #define INF 1 << 29 #define LLINF 1LL << 60 #define REP(i,n) for(int i=0;i</bits/stdc++.h>

aoj 0091

にじみ | Aizu Online Judge dfsを使うところまでは良かったが探索の仕方がまずかった. まず最初に試したのは全ての探索木の節/葉において全部(8*8)を探索する方法でこれだとTLEしてしまった. 自力では解けなかったので先人達の答えを拝見させていただいた. …

aoj 0070

組み合わせの個数 | Aizu Online JudgedfsでやるとTLEしてしまった... int a[10]; int n, s, cnt; void dfs(int m,int r) { if(r > s) return; if(m==n+1) { if(r==s) cnt++; return; } FOR(i,0,9) { if(a[i]) { a[i] = 0; dfs(m+1,r+m*i); a[i] = 1; } } } …