寝癖頭の解法

学習中の覚え書きを投稿、更新していきます。

Aizu Online Judge in C++ #Volume0 - 0017 : Caesar Cipher

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

・問題 "Caesar Cipher"
https://onlinejudge.u-aizu.ac.jp/problems/0017
・シーザー暗号
僕が作成、提出したコードは、以下のとおりです。

・Aizu Online Judge in C++ #Volume0 - 0017 : Caesar Cipher
/*
Aizu Online Judge in C++ #Volume0 - 0017 : Caesar Cipher
 https://onlinejudge.u-aizu.ac.jp/problems/0017
 提出コードの解答例
 https://neguse-atama.hatenablog.com
*/
#include<bits/stdc++.h>
using namespace std;
using ll=long long;
int main(void){
    string s;
    while(getline(cin,s)){
        for(ll i=0;i<26;i++){
            for(ll j=0;j<s.size();j++){
                if('a'<=s[j] && s[j]<='z'){
                    s[j]=((s[j]-'a'+1)%26+'a');
                }
            }
            if(s.find("the")!=string::npos || s.find("this")!=string::npos || s.find("that")!=string::npos){
                break;
            }
        }
        cout<<s<<endl;
    }
    return 0;
}

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




Aizu Online Judge in C++ #Volume0 - 0032 : Plastic Board

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

・問題 "Plastic Board"
https://onlinejudge.u-aizu.ac.jp/problems/0032
・プラスティック板
僕が作成、提出したコードは、以下のとおりです。

・Aizu Online Judge in C++ #Volume0 - 0032 : Plastic Board
/*
Aizu Online Judge in C++ #Volume0 - 0032 : Plastic Board
 https://onlinejudge.u-aizu.ac.jp/problems/0032
 提出コードの解答例
 https://neguse-atama.hatenablog.com
*/
#include<bits/stdc++.h>
using namespace std;
using ll=long long;
int main(void){
    ll a,b,c,ans=0,a2=0;
    while(scanf("%d,%d,%d",&a,&b,&c)!=EOF){
        if(a*a+b*b==c*c){
            ans++;
        }
        if(a==b){
            a2++;
        }
    }
    cout<<ans<<endl<<a2<<endl;
    return 0;
}

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




Aizu Online Judge in C++ #Volume0 - 0023 : Circles Intersection

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

・問題 "Circles Intersection"
https://onlinejudge.u-aizu.ac.jp/problems/0023
・円の交差判定
僕が作成、提出したコードは、以下のとおりです。

・Aizu Online Judge in C++ #Volume0 - 0023 : Circles Intersection
/*
Aizu Online Judge in C++ #Volume0 - 0023 : Circles Intersection
 https://onlinejudge.u-aizu.ac.jp/problems/0023
 提出コードの解答例
 https://neguse-atama.hatenablog.com
*/
#include<bits/stdc++.h>
using namespace std;
int main(void){
    int n;
    cin>>n;
    while(n--){
        double a,b,c,d,e,f;
        cin>>a>>b>>c>>d>>e>>f;
        double g=sqrt((a-d)*(a-d)+(b-e)*(b-e));
        if(g+c<f){
            cout<<-2<<endl;
        }else if(g+f<c){
            cout<<2<<endl;
        }else if(g>c+f){
            cout<<0<<endl;
        }else{
            cout<<1<<endl;
        }
    }
    return 0;
}

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