結果
| 問題 | No.1292 パタパタ三角形 | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2020-11-20 21:38:11 | 
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 58 ms / 2,000 ms | 
| コード長 | 1,030 bytes | 
| コンパイル時間 | 2,191 ms | 
| コンパイル使用メモリ | 200,088 KB | 
| 最終ジャッジ日時 | 2025-01-16 02:10:48 | 
| ジャッジサーバーID (参考情報) | judge2 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 14 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
typedef long long int ll;
typedef unsigned long long ull;
int main(){
	cin.tie(nullptr);
	ios::sync_with_stdio(false);
	string s; cin >> s;
	int n=s.size();
	set<pair<int,int>> st;
	st.insert({0,0});
	int x=0,y=0;
	bool f=true;
	vector<int> a={0,1,2};
	auto Move=[](int &x,int &y,bool &f,vector<int> &a,int num)->void{
		int id;
		for(int i=0;i<3;i++){
			if(a[i]==num)id=i;
		}
		if(f){
			if(id==0)x--;
			else if(id==1)x++;
			else y--;
			f=false;
			vector<int> b=a;
			if(id==0){
				for(int i=0;i<3;i++){
					a[i]=b[(i+3-1)%3];
				}
			}
			else if(id==1){
				for(int i=0;i<3;i++){
					a[i]=b[(i+1)%3];
				}
			}
		}
		else{
			if(id==0)x--;
			else if(id==1)x++;
			else y++;
			f=true;
			vector<int> b=a;
			if(id==0){
				for(int i=0;i<3;i++){
					a[i]=b[(i+3-1)%3];
				}
			}
			else if(id==1){
				for(int i=0;i<3;i++){
					a[i]=b[(i+1)%3];
				}
			}
		}
	};
	for(int i=0;i<n;i++){
		Move(x,y,f,a,s[i]-'a');
		st.insert({x,y});
	}
	cout << st.size() << endl;
}
            
            
            
        