2011/07/11

ジプシーダンス(ドラゴンクエスト4)のピアノ編曲

音を減らして簡単にしたけどそれでも電子ピアノじゃ上手く弾ける気が
しないので、(生ピアノで練習できるようになった時のために)とりあえずMuseScoreっていうフリーの楽譜ソフトで打ち込んでみた。何故かsfが入力できなかったり、ラ#→シ♭ ができなかったりw

一応補足
・5小節目の右手はG#を32で同音打鍵する(ラフマニのA-minorのエチュードみたいに)
・14,16,18小節目のアクセントの音は保持(4部音符を重ねて記述できなかったので)
・繰り返し後の右手の最初の2つの音はオクターブ↑

File
http://goo.gl/DNOkW 
Musescore
http://musescore.org/

2011/03/27

AAAABBBBAAAABBB

2つの文字 A, B を使って作られる長さ 15 の順列のうち次の条件を満たすものは何個あるか.
条件: 「連続する2文字の (順序) 対として AA が 5 回, AB, BA, BB が各 3 回現れる.」
例えば順列 AABBAAAABAABBBB は, AA が 5 回, AB が 3 回, BA が 2回, BB が 4 回現れるので, 上の条件を満たしていない.
1991年数オリ予選より


解けなかったので、悔しいから(&ヒマだから)プログラムで。

解答の方針はA→B、B→Aと変わる所に注目して、
ABとBAが3回出現するから
Aの”カタマリ”をa,Bのカタマリをbとすると、有り得るのは
abababa
または
bababab
の2つの場合。
両方を数え上げればおk(980通り)

細かい解説は多分どこかにあるんで検索してください。

んで、一般化したときに(上の条件はAとBだけで、4パターン全て出てる。ABCで作った列で、AB,ACが1回ずつある時のみカウントとか)力技以外で解く方法とかあるのかにゃ?


#include 
#include 

int N=15;

int chk(int a[]){
 
 int cntAA=0;
 int cntBB=0;
 int cntBA=0;
 int cntAB=0;
 
 for(int i=1;i<=N-1;i++){
  
  if(a[i]==0 && a[i+1]==0)
   cntAA++;
   
  if(a[i]==0 && a[i+1]==1)
   cntAB++;
  
  if(a[i]==1 && a[i+1]==0)
   cntBA++;
  
  if(a[i]==1 && a[i+1]==1)
   cntBB++;
  
 }

 
 if(cntAA==5 && cntAB==3 && cntBA==3 && cntBB==3){
  
  return 1;
 
 }else{
  
  return 0;
  
 }
 
}
 
 

int main(void)
{

 int a[N+1];
 int count=0;
 
 int MAX=pow(2,15)-1;

 for(int n=0;n<=MAX;n++){
  
  //10進数→2進数
  for(int i=1;i<=N;i++)
   a[i]=(n/(int)pow(2,i-1))%2;
  
 
  if(chk(a))count++;
  
 }

 printf("%d",count);
 
 return 0;
}

2011/02/02

自然数をn乗して得られるn桁の正整数は何個あるか?

Project Eular Problem63

5桁の数 16807 = 75は自然数を5乗した数である. 同様に9桁の数 134217728 = 89も自然数を9乗した数である.
自然数をn乗して得られるn桁の正整数は何個あるか?
http://odz.sakura.ne.jp/projecteuler/index.php?cmd=read&page=Problem%2063

nは10-Ceiling[10^((n - 1)/n)]>=1
を満たすn=21までカウントすればおk(2項目は増加関数)。


int main (int argc, const char * argv[]) {
   
 double count=0;
 for(double n=1;n<=21;n++){
  
  count=count+ceil(10)-ceil(pow(10,(n-1)/n)); 
  
 }
 
 printf("%f",count);
 
} 


コレの原文(英語)読みながらやったら少しは英語力wがマシになるのかなーと、思いつつ、日本語約を先に読むと英文を読む気にならない。。。。

2011/01/19

レイトン教授と最後の時間旅行ナゾ123



4*4で最大いくつ置けるかって問題。数学オリンピックの過去問題にほぼ同じ問題があったので、正確に9個置ける証明を知りたい人のために。確か1974年のソ連の国内大会で、数オリ攻略本からのほぼパクリ回答です(p.164あたり)。



考え方は鳩ノ巣原理でOK
最大個数Mと配置出来たとする。
タテ4行のうち2行選んだとして、行を選ぶ総数は4C2=6行。
ある行の石の数をp_iとすると占拠する列の数は4Cp_i。
もちろん
Σ_i p_i=M
よって
Σ_i 4Cp_i <= 4C2
を満たすMを求めればOK

6 >= Σ_i (pi,2)
=Σ_i pi(pi-1)/2

12 >= Σ_i p_i(p_i-1)
=Σ_i (p_i^2-p_i)
=Σ_i (p_i^2)-M
>= (Σ_i pi)^2/4 -M (Mにしたいからコーシー・シュワルツの不等式。証明はてきとーな本みてください。)
=M^2/4-M

整理すると
M^2-4M-48 <=0
M <= 2*√13+2 ≒ 9.211
Mは整数なんで9個が最大。

間違いあったら報告お願いします。