第9回日本情報オリンピック 予選(オンライン)の過去問から、その提出コードの解答例です。
AtCoderとは、コンテストを通じて、プログラミングやアルゴリズムを学習するサービスです。
atcoder.jp
プログラミングコンテストとは、「与えられた問題をいかに素早く、正確に」解くことができるかを競うものです。
「競技プログラミング」を略して、「競プロ」などと呼ばれています。
#D - カード並べ
atcoder.jp
僕が作成、提出したコードは、以下のとおりです。
/* AtCoder Problems in C++ #D - カード並べ https://atcoder.jp/contests/joi2010yo/tasks/joi2010yo_d 提出コードの解答例 https://neguse-atama.hatenablog.com */ #include<bits/stdc++.h> using namespace std; int main(void){ int n,k; cin>>n>>k; vector<int> v(n),num(n); map<string,int> num2; for(int i=0;i<n;i++){ cin>>v[i]; num[i]=i; } do{ vector<int> v2(k); for(int i=0;i<k;i++){ v2[i]=num[i]; } string Nstr=to_string(v[v2[0]]); for(int i=1;i<k;i++){ Nstr+=to_string(v[v2[i]]); } num2[Nstr]; }while(next_permutation(num.begin(),num.end())); cout<<num2.size()<<endl; return 0; }
第9回日本情報オリンピック 予選(オンライン)は、オンラインジャッジによるプログラミングコンテストです。
AtCoderのコンテストは日本語と英語に対応していて、週末ごとに実施されているみたいです。
https://practice.contest.atcoder.jp/tutorial
アカウントを登録すれば、誰でも参加できます。