Tamflexの貯蔵庫

やる気のない備忘録

複数プロジェクトが併存できるC++用の汎用的なMakefile

c++

汎用的に使えるMakefileを作ってみた github.com詳細はこちらから qiita.com

anaconda3でgraph_toolを使う

ubuntuでgraph_tool(graph-tool: Efficent network analysis with python)を使うときには、以下のリンクに従ってレポジトリを登録したあと、以下のコマンドで簡単にインストールできる。 sudo apt install python-graph-tool # python2 version sudo apt ins…

フィボナッチ数の一般項

フィボナッチ数の一般項は以下の式で表される。 これを展開して、無理数をなくしてあげると以下のようになる。 計算量はである。例えばpython3で実装すれば以下のようになる。 import scipy.misc as scm import math fib = lambda n : int(sum([scm.comb(n,2…

ssh設定の備忘録

よく設定する癖によく忘れるので備忘録を書きます クライアント側設定 鍵の作成 $ ssh-keygen -t rsa -b 4096 -C "your_email@example.com" 鍵にかかっているパスワードの変更 $ ssh-keygen -p Enter file in which the key is (/home/user/.ssh/id_rsa): [P…

codeIQ 2751

図形に関して, 3*7の長方形を3個つなげた対称性の高い空間だと言える. これらの長方形をそれぞれworld 0,1,2として範囲外に出たら「奈落」/「ワープ」させる条件分岐を書けばわかりやすいかもしれない. 文字の変換についてだが, こちらもASCIIコードを駆使し…

codeIQ 2767

説明が不十分だと思うのだけど, 同じ類似度の時にインデックスの小さい方を先に出さないとtest case2で落ちる. int tn; vector<int> ns; vector<int> tmp; int norm(vector<int> v) { int ans = 0; int until = v.size()-1; FOR(i,1,until) ans+=v[i]*v[i]; return ans; } i</int></int></int>…

codeIQ 1678

count{|a|...}はブロックの返り値でtrueとなるもののみをcountする. b,e=gets.split(',').map(&:to_i);$><<[*b+1..e-1].count{|a|a.to_s(2).reverse==a.to_s(2)}

codeIQ 1630

abc029にも似た, というかほぼ同じな問題があった. 念の為long long intを用いて解いた. void solve(ll n) { n++; ll d = 1, t, ans = 0; while(n>d) { t = d; d *= 10; ans += (n/d)*t+(n%d>t*7?(n%d>=t*8?t:(n%d)%t):0); } cout << ans << "\n"; } int mai…

codeIQ 1621

なんとなくlower_boundでやりたかった. vector<ll> p; void init() { p.resize(10000); fill(p.begin(),p.end(),1LL<<30); int m = 0; p[m++] = 2; for(int i=3;i<=100000;i+=2) { bool flag = true; for(int j=0;p[j]*p[j]<=i;j++) { if(i%p[j]==0) { flag = fa</ll>…

【python】pythonで変数名を取得する

ラムダ式で書いてみた var_name = lambda val : [k for k, v in globals().items() if id(v) == id(val)] a = 1 s = var_name(a)[0]

【c++11】warning: deleting object of polymorphic class type ‘Derived’ which has non-virtual destructor might cause undefined behaviour [-Wdelete-non-virtual-dtor]

自作クラスでdeleteでデストラクタを呼ぼうとしたら以下のような警告が出た。 warning: deleting object of polymorphic class type ‘Derived’ which has non-virtual destructor might cause undefined behaviour [-Wdelete-non-virtual-dtor] delete v;こ…

テンプレートクラスTの内部クラスを呼び出す

共通の内部クラスを持っている複数のクラスをつくって、テンプレートからそれを呼び出したいことがあるかもしれません。その時は以下のように書けばうまく動くでしょう。 #include <iostream> using namespace std; class A1 { public: struct Param { Param(){cout <<</iostream>…

循環少数のプログラム

c

フロイドの循環検出法 - Wikipedia これを使うらしい int f(int n) { int p = 1, q = 1; int s = 0, t = 0; // start : s, goal : t while(1) { p = (p*10)%n; q = (q*10)%n; q = (q*10)%n; if(p==q) break; } if(p!=0) { q = 1; s = 1; while(p!=q) { s++; …

aoj 0503

少し考えれば一番下のものを順番に移動していくしかないことがわかります。 置く場所を#0,#1,#2としてgoalを#0に固定する。1〜nまでのコップが順に並んだものが #0にあるとき => 0 #1にあるとき => 3^n #2にあるとき => 2*3^n したがって下のコードのように…

パスワードで保護されているpdfファイルを解除する

パスワードクラックの方法ではないのであしからず。配布された資料のパスワードを逐一解除するのは手間がかかるし、将来見たい時には忘れているかもしれない。 それに個人的に利用する限りでは、パスワードを解除してもそれほど問題にはならない(あくまで個…

aoj 0502

サイコロ | Aizu Online Judgeクラスを使えば結構綺麗にかけるかもしれないけど、まあ個人的な趣味でしょう。 今回はわかりやすさのために変数を3つ導入したけど、サイコロの現在の姿勢は2変数で書けます。文字数チャレンジをする人はここらへんを切り詰める…

aoj 0501

データ変換 | Aizu Online JudgeC++は便利だけどもcだけで書いたほうが勉強になりそうです。 int main() { int n,m; string s,t; string ans; while(cin >> n) { if(n == 0) break; map<string,string> d; REP(i,n) { cin >> s >> t; d[s] = t; } cin >> m; ans = ""; REP(i</string,string>…

ssh経由でリモートとローカルを判別してLAN内のサーバに接続する

LANの中にgitBucket用のサーバがあり、ノートPCでLANの内側・外側の両方から切り替えを自動化してアクセスしたいと考えて.ssh/configの設定を考えてみた。自分がLANの内側か外側にあるのか判別するにはnslookupを使えばいいことに気が付き以下のように.ssh/c…

arc 059

arc059.contest.atcoder.jp 飴が個,人がのときの答えをとおけば以下の漸化式が成立する。 の部分は最初に計算しておいてのオーダで計算できて結局時間計算量は template <long long modulo> class Modulo { private: long long pow(long long q) { long long a=1; long long y=</long>…

ファイル名を一括置換

ファイル名を一括で置換したいシチュエーションはたくさんあると思うけど、そういう時に逐一find-sedコマンドを使うのが面倒なときはrenameコマンドを使うといいでしょう。 Linuxであればどのディストリビューションにもおそらく入っていると思われます。 使…

abc 040

abc040.contest.atcoder.jp解説を勉強してみた トポロジカルソートの場合の数の算出をbitDPを用いてO(n!)をO(m2^n)にする問題 (頂点集合Sとおいた時のルートの要素数) とおけば以下の漸化式で求まる ただし からへの辺が存在しない 集合をbit列で表し小さい…

ubuntu 16.04のwifiの不具合について

14.04からアップグレードしたのは良いもののwifiのアクセスポイントが見つからなくなってしまった。 復旧方法は以下の通り sudo iwconfigで無線LANのインターフェース名を知りましょう。あとは sudo ifconfig [interface] up sudo service network-manager r…

codeIQ 2529

codeiq.jpf,gは割と簡単だけど,hが面倒. #include <bits/stdc++.h> #define EPS 1e-10 ll power(ll x,ll n){ll a=1;REP(i,n)a*=x;return a;} ll f(double a, double b, double c, double d) { double e = 180-(b+c+d); double f = 180-(a+b+c); a *= M_PI/180; b *= M_PI/18</bits/stdc++.h>…

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>…

abc 040

abc040.contest.atcoder.jpunion findを使いましょう. 新しい道からどんどん素集合データ構造を更新して行って,その時の各クエリが要求するノードが含まれる集合の濃度(要素数)を記憶,あとで出力すればとける. unionfind自体は知っていてなんとなく使う気が…

abc 039

abc039.contest.atcoder.jp白の周囲を白にして、その後黒の周囲を黒にして元に戻るか判定する. int h,w; int a[100][100]; int b[100][100]; int c[100][100]; bool range(int x, int y) { return x >= 0 && x < h && y >= 0 && y < w; } int main() { cin >…

abc 037

abc037.contest.atcoder.jp DPの問題. 点を始点とする場合の数はその点の周囲のマス+1になる.あとは再帰的に計算してメモ化すればできる. ll T[1010][1010]; ll dp[1010][1010]; int h, w; ll f(int x, int y, ll p) { if(x<0||x>=h||y<0||y>=w) return 0; i…

ubuntuで「画面だけ」オフにしたい

ノートpcにubuntuを入れているのだけど, 開いた状態のまま,サスペンドせずに画面だけオフにするには以下のコマンドを打てばいい $ xset dpms force standby これで強制的にスタンバイ状態にできる. もしノートpcを閉じてもサスペンドしたくなければ以下を参…

abc 038

LISの二次元バージョン.x座標でソートしてy座標のLISを求めればいい ここでうまいと思ったのはy座標を負にすること. 問題では狭義単調増加の最長増加列を求めさせているので,x座標が同じだと条件に合わない. そこで負にすることで絶対値が大きい順に並べこれ…

codeIQ 2796

codeiq.jp期待値を計算すればよい あとはargminなので以下のように簡略化できる. p [*1..n=eval(*$<)].max_by{|t|(n-t).to_f*(n+t-1)/(n+1-t)}