寝癖頭の解法

小学生の目線から、勉強中の覚え書きを投稿、更新していきます。

Aizu Online Judge in C++ #Volume0 - 0083 : Era Name Transformation

Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。

・問題 "Era Name Transformation"
https://onlinejudge.u-aizu.ac.jp/problems/0083
・西暦和暦変換
僕が作成、提出したコードは、以下のとおりです。

・Aizu Online Judge in C++ #Volume0 - 0083 : Era Name Transformation
/*
Aizu Online Judge in C++ #Volume0 - 0083 : Era Name Transformation
 https://onlinejudge.u-aizu.ac.jp/problems/0083
 提出コードの解答例
 https://neguse-atama.hatenablog.com
*/
#include<bits/stdc++.h>
using namespace std;
using ll=long long;
int main(void){
    ll y,m,d,x;
    while(cin>>y>>m>>d){
        x=y*10000+m*100+d;
        if(x<18680908){
            printf("pre-meiji\n");
		}else if(x<19120730){
		    printf("meiji %d %d %d\n",y-1867,m,d);
		}else if(x<19261225){
		    printf("taisho %d %d %d\n",y-1911,m,d);
		}else if(x<19890108){
		    printf("showa %d %d %d\n",y-1925,m,d);
		}else{
		    printf("heisei %d %d %d\n",y-1988,m,d);
		}
    }
    return 0;
}

設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/




Aizu Online Judge in C++ #Volume0 - 0077 : Run Length

Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。

・問題 "Run Length"
https://onlinejudge.u-aizu.ac.jp/problems/0077
・ランレングス
僕が作成、提出したコードは、以下のとおりです。

・Aizu Online Judge in C++ #Volume0 - 0077 : Run Length
/*
Aizu Online Judge in C++ #Volume0 - 0077 : Run Length
 https://onlinejudge.u-aizu.ac.jp/problems/0077
 提出コードの解答例
 https://neguse-atama.hatenablog.com
*/
#include<bits/stdc++.h>
using namespace std;
using ll=long long;
int main(void){
    char c,n;
    for(;cin.get(c);){
        n='1';
        if(c=='@'){
            cin>>n>>c;
        }
        for(;n-->'0';){
            cout<<c;
        }
    }
    return 0;
}

設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/




Aizu Online Judge in C++ #Volume0 - 0097 : Sum of Integers II

Aizu Online Judge(AOJ)の過去問から、その提出コードの解答例です。

・問題 "Sum of Integers II"
https://onlinejudge.u-aizu.ac.jp/problems/0097
・整数の和 II
僕が作成、提出したコードは、以下のとおりです。

・Aizu Online Judge in C++ #Volume0 - 0097 : Sum of Integers II
/*
Aizu Online Judge in C++ #Volume0 - 0097 : Sum of Integers II
 https://onlinejudge.u-aizu.ac.jp/problems/0097
 提出コードの解答例
 https://neguse-atama.hatenablog.com
*/
#include<bits/stdc++.h>
using namespace std;
using ll=long long;
ll dp[10][1024];
int main(void){
    dp[0][0]=1;
    for(ll i=0;i<=100;i++){
        for(ll j=9;j--;){
            for(ll k=0;k+i<=1000;k++){
                dp[j+1][k+i]+=dp[j][k];
            }
        }
    }
    ll n,s;
    while(cin>>n>>s,n||s){
        cout<<dp[n][s]<<endl;
    }
    return 0;
}

設問の出典は、プログラミング問題のオンライン採点システム「Aizu Online Judge(AOJ)」です。
http://judge.u-aizu.ac.jp/onlinejudge/