結果
問題 | No.8078 Very Simple Traveling Salesman Problem |
ユーザー | plcherrim |
提出日時 | 2021-04-01 22:06:04 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 4,762 bytes |
コンパイル時間 | 4,460 ms |
コンパイル使用メモリ | 269,404 KB |
最終ジャッジ日時 | 2025-01-20 06:49:14 |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
6,824 KB |
testcase_01 | AC | 1 ms
6,824 KB |
testcase_02 | AC | 1 ms
6,820 KB |
testcase_03 | AC | 2 ms
6,824 KB |
testcase_04 | AC | 2 ms
6,820 KB |
testcase_05 | AC | 2 ms
6,816 KB |
testcase_06 | AC | 1 ms
6,816 KB |
testcase_07 | AC | 2 ms
6,820 KB |
testcase_08 | AC | 2 ms
6,820 KB |
testcase_09 | AC | 1 ms
6,816 KB |
testcase_10 | AC | 1 ms
6,816 KB |
ソースコード
// #pragma GCC target("avx") // #pragma GCC optimize("O3,inline,omit-frame-pointer,no-asynchronous-unwind-tables,fast-math") // #pragma GCC optimize("unroll-loops") #define _USE_MATH_DEFINES #ifndef _DEBUG #define NDEBUG #endif #if defined(ONLINE_JUDGE) || defined(_DEBUG) #include <atcoder/all> using namespace atcoder; #endif #include<bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> using namespace std; using ll=long long; using ld=long double; using ull=unsigned long long; using vb=vector<bool>; using vvb=vector<vb>; using vd=vector<double>; using vvd=vector<vd>; using vi=vector<int>; using vvi=vector<vi>; using vl=vector<ll>; using vvl=vector<vl>; using pll=pair<ll,ll>; using tll=tuple<ll,ll>; using tlll=tuple<ll,ll,ll>; using vs=vector<string>; template<class K> using IndexedSet=__gnu_pbds::tree<K,__gnu_pbds::null_type,less<K>,__gnu_pbds::rb_tree_tag,__gnu_pbds::tree_order_statistics_node_update>; template<class K> using HashSet=__gnu_pbds::gp_hash_table<K,__gnu_pbds::null_type>; template<class K,class V> using IndexedMap=__gnu_pbds::tree<K,V,less<K>,__gnu_pbds::rb_tree_tag,__gnu_pbds::tree_order_statistics_node_update>; template<class K,class V> using HashMap=__gnu_pbds::gp_hash_table<K,V>; #define all(a) a.begin(),a.end() #define rall(a) a.rbegin(),a.rend() #define loop(q) __loop(q, __LINE__) #define __loop(q,l) __loop2(q,l) #define __loop2(q,l) rep(_lp ## l,q) #define rep(i,n) range(i,0,n) #define rrep(i,n) rrange(i,0,n) #define range(i,a,n) for(ll i=((ll)a);i<((ll)n);++i) #define rrange(i,a,n) for(ll i=((ll)n-1);i>=((ll)a);--i) #define repsq(i,n) for(ll i=0;i*i<=n;++i) #define each(v,a) for(auto v:a) #define eachref(v,a) for(auto&v:a) #define fcout(a) cout<<setprecision(a)<<fixed constexpr ll LINF=1ll<<60; constexpr int INF=1<<30; constexpr double EPS=(1e-9); constexpr ll MOD=1000000007ll; constexpr double PI=3.1415926535897932384; void Main(); int main(){cin.tie(nullptr);ios::sync_with_stdio(false);Main();return 0;} template<class T>constexpr bool chmax(T&a,T b){return a<b?a=b,1:0;} template<class T>constexpr bool chmin(T&a,T b){return a>b?a=b,1:0;} template<class S>S sum(vector<S>&a){return accumulate(all(a),S());} template<class S>S max(vector<S>&a){return *max_element(all(a));} template<class S>S min(vector<S>&a){return *min_element(all(a));} //output template<class T>struct hasItr{ template<class U>static constexpr true_type check(class U::iterator*); template<class U>static constexpr false_type check(...); static constexpr bool v=decltype(check<T>(nullptr))::value; }; template<>struct hasItr<string>{static constexpr bool v=false;}; template<class T>void puta(T&t,false_type,ostream&os,[[maybe_unused]]char el){os<<t;} template<class T>void puta(T&t,true_type,ostream&os,char el){ constexpr bool h=hasItr<typename T::value_type>::v; bool F=true,I; for(auto&i:t){ if(!F)os<<' '; puta(i,bool_constant<h>(),os,el); F=I=h; } if(!I)os<<el; } template<class T>void puta(const T&t, ostream&os=cout, char el='\n'){ puta(t,bool_constant<hasItr<T>::v>(),os,el); if(!hasItr<T>::v)os<<el; } template<class H,class...T>void puta(const H&h,const T&...t){cout<<h<<' ';puta(t...);} template<size_t i,class...T>void puta(tuple<T...>const&t, ostream&os){ if constexpr(i==sizeof...(T)-1)puta(get<i>(t),os); else{os<<get<i>(t)<<' ';puta<i+1>(t,os);} } template<class...T>void puta(tuple<T...>const&t, ostream&os=cout){puta<0>(t,os);} template<class S,class T>constexpr ostream&operator<<(ostream&os,pair<S,T>p){ os<<'['<<p.first<<", "; if constexpr(hasItr<T>::v)puta(p.second,bool_constant<true>(),os,']'); else os<<p.second<<']'; return os; }; template<class...T>constexpr ostream&operator<<(ostream&os,tuple<T...>t){puta(t,os); return os;} void YN(bool b){puta(b?"YES":"NO");} void Yn(bool b){puta(b?"Yes":"No");} #ifdef _DEBUG template<class T>void dump_f(const T&t){puta(t,cerr);} template<class H,class...T>void dump_f(const H&h,const T&...t){cerr<<h<<' ';dump_f(t...);} template<class...T>void dump_f(tuple<T...>const&t){puta(t,cerr);} #define dump(...)cerr<<" "<<string(#__VA_ARGS__)<<": ["<<to_string(__LINE__)<<":"<<__FUNCTION__<<"]\n ",dump_f(__VA_ARGS__) #else #define dump(...) #endif //input template<class S>auto&operator>>(istream&is,vector<S>&t){for(S&a:t)cin>>a;return is;} template<typename...S>void geta_(S&...s){((cin>>s),...);} #define geta(t,...) t __VA_ARGS__;geta_(__VA_ARGS__) template<class T,class...Args>auto vec(T x,int arg,Args...args){if constexpr(sizeof...(args)==0)return vector(arg,x);else return vector(arg,vec(x,args...));} #define getv(a,...) auto a=vec(__VA_ARGS__);cin>>a // ライブラリ貼るスペース void Main(){ //-8.245 + 6.807H + 7.073FFC geta(ll,n,m); puta(n); }