結果
| 問題 |
No.801 エレベーター
|
| コンテスト | |
| ユーザー |
wakannyaai
|
| 提出日時 | 2020-02-02 10:13:29 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
MLE
|
| 実行時間 | - |
| コード長 | 8,721 bytes |
| コンパイル時間 | 2,471 ms |
| コンパイル使用メモリ | 197,636 KB |
| 実行使用メモリ | 823,552 KB |
| 最終ジャッジ日時 | 2024-09-18 20:33:56 |
| 合計ジャッジ時間 | 18,555 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 10 MLE * 1 -- * 15 |
ソースコード
/*やったぜ。 投稿者:変態糞土方 (8月16日(水)07時14分22秒)
昨日の8月15日にいつもの浮浪者のおっさん(60歳)と先日メールくれた汚れ好きの土方のにいちゃん
(45歳)とわし(53歳)の3人で県北にある川の土手の下で盛りあったぜ。
今日は明日が休みなんでコンビニで酒とつまみを買ってから滅多に人が来ない所なんで、
そこでしこたま酒を飲んでからやりはじめたんや。
3人でちんぽ舐めあいながら地下足袋だけになり持って来たいちぢく浣腸を3本ずつ入れあった。
しばらくしたら、けつの穴がひくひくして来るし、糞が出口を求めて腹の中でぐるぐるしている。
浮浪者のおっさんにけつの穴をなめさせながら、兄ちゃんのけつの穴を舐めてたら、
先に兄ちゃんがわしの口に糞をドバーっと出して来た。
それと同時におっさんもわしも糞を出したんや。もう顔中、糞まみれや、
3人で出した糞を手で掬いながらお互いの体にぬりあったり、
糞まみれのちんぽを舐めあって小便で浣腸したりした。ああ~~たまらねえぜ。
しばらくやりまくってから又浣腸をしあうともう気が狂う程気持ちええんじゃ。
浮浪者のおっさんのけつの穴にわしのちんぽを突うずるっ込んでやると
けつの穴が糞と小便でずるずるして気持ちが良い。
にいちゃんもおっさんの口にちんぽ突っ込んで腰をつかって居る。
糞まみれのおっさんのちんぽを掻きながら、思い切り射精したんや。
それからは、もうめちゃくちゃにおっさんと兄ちゃんの糞ちんぽを舐めあい、
糞を塗りあい、二回も男汁を出した。もう一度やりたいぜ。
やはり大勢で糞まみれになると最高やで。こんな、変態親父と糞あそびしないか。
ああ~~早く糞まみれになろうぜ。
岡山の県北であえる奴なら最高や。わしは163*90*53,おっさんは165*75*60、や
糞まみれでやりたいやつ、至急、メールくれや。
土方姿のまま浣腸して、糞だらけでやろうや。*/
#include "bits/stdc++.h"
#include <unordered_set>
#define rep(i,n) for(int i = 0; i < n; i++)
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
#define vll vector<vector<long long>>
#define vl vector<long long>
#define vi vector<int>
#define vii vector<vector<int>>
#define pb push_back
#define pf push_front
#define ld long double
#define Sort(a) sort(a.begin(),a.end())
#define cSort(a,cmp) sort(a.begin(),a.end(),cmp)
#define reSort(a) sort(a.rbegin(), a.rend())
static const ll llMAX = numeric_limits<long long>::max();
static const int intMAX = numeric_limits<int>::max();
static const ll llMIN = numeric_limits<long long>::min();
static const int intMIN = numeric_limits<int>::min();
static const ll d_5 = 100000;
static const ll d9_7 = 1000000007;
static const ll d_9 = 1000000000;
static const double PI=3.14159265358979323846;
//<<std::setprecision(30)
template<class T>
void Printvector(std::vector<T> a){
int size = a.size();
rep(i,size){
cout<<a[i]<<" ";
}
cout<<endl;
}
template<class T>
void Printvector(std::vector<std::vector<T>> a){
int size = a.size();
rep(i,size){
int size2=a[i].size();
rep(j,size2){
cout<<a[i][j]<<" ";
}
cout<<endl;
}
cout<<endl;
}
template<class T>
T digitpower(T a,T b){//aのb乗を計算
int mode=1;
if(b==1){
return a;
}else if(b==0){
return 1;
}
if(b%2==1){
T tmp = digitpower(a,(b-1)/2);
if(mode==0){
tmp%=d9_7;
}
tmp*=tmp;
if(mode==0){
tmp%=d9_7;
}
tmp*=a;
if(mode==0){
return (tmp)%d9_7;
}else{
return tmp;
}
}else{
T tmp = digitpower(a,(b)/2);
if(mode==0){
tmp%=d9_7;
}
tmp*=tmp;
if(mode==0){
tmp%=d9_7;
}
if(mode==0){
return (tmp)%d9_7;
}else{
return tmp;
}
}
}
unordered_map<ll,ll> prime_factor(int64_t n) {
unordered_map<ll,ll> ret;
for(int64_t i = 2; i * i <= n; i++) {
while(n % i == 0) {
ret[i]++;
n /= i;
}
}
if(n != 1) ret[n] = 1;
return ret;
}
struct datas{
int num;
int index;
};
bool cmp(const datas &a, const datas &b)
{
return a.num < b.num;
}
template<class T>
vector<T> getaccum(vector<T> a){//modを取るか取らないかに注意
int size=a.size();
vector<T> ans(size);
ans[0]=a[0];
for(int i=0;i<size-1;i++){
ans[i+1]=ans[i]+a[i+1];
//ans[i+1]%=d9_7;
}
return ans;
}
multiset<int> c;
//木構造グラフ
struct edge{
int to;
ll length;
int num;
int pair;
};
struct treev{
int num;
vector<int> nexts;
};
vector<treev> vs;
vector<edge> es;
int cmax=0;
void createtreenode(int num){//引数は頂点の数
vs=vector<treev>(num);
/*treev* newt;
try{
treev* newt=new treev;
}
catch (std::bad_alloc&) {
// メモリ確保に失敗
// エラー処理
}*/
rep(i,num){
vs[i].num=i;
}
return ;
}
void insertree_bidire(ll len,int Va,int Vb,int num){//結ぶ頂点を
//双方向
es.pb({Va,len,num,-1});
es.pb({Vb,len,num,-1});
int size=es.size();
es[size-1].pair=size-2;
es[size-2].pair=size-1;
vs[Va].nexts.push_back(size-1);
vs[Vb].nexts.push_back(size-2);
return;
}
void insertree_unidire(ll len,int Va,int Vb,int num){//結ぶ頂点を
//単方向,aからbへ
es.pb({Vb,len,num,-1});
int size=es.size();
es[size-1].pair=-1;
vs[Va].nexts.push_back(size-1);
return;
}
void DFS(int root,ll depth,int pre){
//ここにやりたい処理を書く
int ncnt=0;
for(auto i:vs[root].nexts){
if(pre==es[i].to){
continue;
}
DFS(es[i].to,depth+es[i].length,root);
}
return;
}
struct operatedata{
int num;
int prenum;
ll depth;
};
deque<operatedata> opera;
vi past;
int tmpdepthmax=0;
int ngflag;
vi depths_ao;
vi depths_sz;
void BFS1(int ini){
opera.clear();
opera.pb({ini,-1,0});
int pre=-1;
while(opera.size()!=0 &&ngflag==0){
int root=opera.front().num;
int pre=opera.front().prenum;
ll depth=opera.front().depth;
opera.pop_front();
//ここにやりたい処理を書く
depths_ao[root]=depth;
for(int i:vs[root].nexts){
if(es[i].to==pre){
continue;
}
opera.push_back({es[i].to,root,depth+es[i].length});
}
}
return;
}
void BFS2(int ini){
opera.clear();
opera.pb({ini,-1,0});
int pre=-1;
while(opera.size()!=0 &&ngflag==0){
int root=opera.front().num;
int pre=opera.front().prenum;
ll depth=opera.front().depth;
opera.pop_front();
//ここにやりたい処理を書く
depths_sz[root]=depth;
for(int i:vs[root].nexts){
if(es[i].to==pre){
continue;
}
opera.push_back({es[i].to,root,depth+es[i].length});
}
}
return;
}
template<class T>
vector<vector<T>> digitmatrix(vector<vector<T>> mat,ll exponent){
bool mode=true;//falseが、mod取らない
if(exponent==1){
return mat;
}
if(exponent==0){
//単位行列
int n=mat.size();
vector<vector<T>> tmp=vector<vector<T>>(n,vector<T>(n,0));
for(int i=0;i<n;i++){
tmp[i][i]=1;
}
return tmp;
}
vector<vector<T>> tmp=digitmatrix(mat,exponent/2);
int n=mat.size();
vector<vector<T>> tmp2=vector<vector<T>>(n,vector<T>(n,0));
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
for(int k=0;k<n;k++){
tmp2[i][j]+=tmp[i][k]*tmp[k][j];
if(mode){
tmp2[i][j]%=d9_7;
}
}
}
}
tmp=tmp2;
if(exponent%2==1){
//正方行列じゃないとエラー起きる
tmp2=vector<vector<T>>(n,vector<T>(n,0));
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
for(int k=0;k<n;k++){
tmp2[i][j]+=tmp[i][k]*mat[k][j];
if(mode){
tmp2[i][j]%=d9_7;
}
}
}
}
tmp=tmp2;
}
return tmp;
}
int main(void){
ll n,m,k;
cin>>n>>m>>k;
vl l(m),r(m);
rep(i,m){
cin>>l[i]>>r[i];
l[i]--;
r[i]--;
}
vll pluss(n,vl(n,0));
rep(i,n){
//iさんが各フロアへ移動するパターン数
rep(j,m){
if(!(l[j]<=i && i<=r[j]))continue;
pluss[max((ll)0,l[j])][i]++;
if(r[j]<n-1){
pluss[r[j]+1][i]--;
}
}
rep(j,n-1){
pluss[j+1][i]+=pluss[j][i];
}
}
//Printvector(pluss);
vl tmp(n);
vl nowsum(n,0);
rep(i,k){
vl foraccum(n,0);
tmp=vl(n,0);
}
vll ans=digitmatrix(pluss,k);
cout<<ans[n-1][0]<<endl;
return 0;
}
wakannyaai