Submission #1811967


Source Code Expand

///////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////
//                       _oo0oo_                         //
//                      o8888888o                        //
//                      88" . "88      ------ hzt1       //
//                      (| -_- |)                        //
//                      0\  =  /0                        //
//                    ___/`---'\___                      //
//                  .' \|     |// '.                     //
//                 / \|||  :  |||// \                    //
//                / _||||| -:- |||||- \                  //
//               |   | \  -  /// |     |                 //
//               | \_|  ''\---/''  |_/ |                 //
//               \  .-\__  '-'  ___/-. /                 //
//             ___'. .'  /--.--\  `. .'___               //
//          ."" '<  `.___\_<|>_/___.' >' "".             //
//         | | :  `- \`.;`\ _ /`;.`/ - ` : | |           //
//         \  \ `_.   \_ __\ /__ _/   .-` /  /           //
//     =====`-.____`.___ \_____/___.-`___.-'=====        //
//                       `=---='                         //
//                                                       //
//                                                       //
//     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~       //
//                                                       //
//                 God-He Bless All.                     //
//           This Code Will Never Explode.               //
//                                                       //
//                                                       //
///////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////
#include<cstdio>
#include<cstring>
#include<cctype>
#include<algorithm>
#include<vector>
#define pb push_back
#define mp make_pair
#define xx first
#define yy second
#define rep(i,a,b) for(int i=(a),i##_end_=(b);i<=i##_end_;i++)
#define dwn(i,a,b) for(int i=(a),i##_end_=(b);i>=i##_end_;i--)
using namespace std;
const int Size=1<<16;
char buffer[Size],*head,*tail;
inline char Getchar() {
    if(head==tail) {
        int l=fread(buffer,1,Size,stdin);
        tail=(head=buffer)+l;
    }
    if(head==tail) return -1;
    return *head++;
}
inline int read() {
    int x=0,f=1;char c=getchar();
    for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
    for(;isdigit(c);c=getchar()) x=x*10+c-'0';
    return x*f;
}
typedef long long ll;
typedef pair<int,int> pii;
const int maxn=100010;
const int mod=1000000007;
struct Matrix {
	int A[3][3];
	Matrix operator * (const Matrix& b) const {
		Matrix c;
		rep(i,0,2) rep(j,0,2) {
			int res=0;
			rep(k,0,2) (res+=(ll)A[i][k]*b.A[k][j]%mod)%=mod;
			c.A[i][j]=res;
		}
		return c;
	}
}I={1,0,0,0,1,0,0,0,1},A={1,0,1,2,1,2,1,1,2},B={1,0,0,2,1,0,1,1,1};
Matrix operator ^ (Matrix A,int n) {
	Matrix c;c=I;
	for(;n;n>>=1,A=A*A) if(n&1) c=c*A;
	return c;
}
int n,m,x[maxn];
int main() {
	n=read();m=read();
	Matrix ans;ans=I;
	x[0]=-1;x[m+1]=n;
	rep(i,1,m) x[i]=read();
	rep(i,1,m+1) {
		ans=(A^(x[i]-x[i-1]-1))*ans;
		if(i!=m+1) ans=B*ans;
	}
	int res=ans.A[2][0];
	printf("%d\n",res);
	return 0;
}

Submission Info

Submission Time
Task E - Placing Squares
User wzj52501
Language C++14 (GCC 5.4.1)
Score 1600
Code Size 3331 Byte
Status AC
Exec Time 249 ms
Memory 512 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 1600 / 1600
Status
AC × 4
AC × 38
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt, sample_04.txt
All sample_01.txt, sample_02.txt, sample_03.txt, sample_04.txt, sample_01.txt, sample_02.txt, sample_03.txt, sample_04.txt, subtask_1_01.txt, subtask_1_02.txt, subtask_1_03.txt, subtask_1_04.txt, subtask_1_05.txt, subtask_1_06.txt, subtask_1_07.txt, subtask_1_08.txt, subtask_1_09.txt, subtask_1_10.txt, subtask_1_11.txt, subtask_1_12.txt, subtask_1_13.txt, subtask_1_14.txt, subtask_1_15.txt, subtask_1_16.txt, subtask_1_17.txt, subtask_1_18.txt, subtask_1_19.txt, subtask_1_20.txt, subtask_1_21.txt, subtask_1_22.txt, subtask_1_23.txt, subtask_1_24.txt, subtask_1_25.txt, subtask_1_26.txt, subtask_1_27.txt, subtask_1_28.txt, subtask_1_29.txt, subtask_1_30.txt
Case Name Status Exec Time Memory
sample_01.txt AC 1 ms 128 KB
sample_02.txt AC 1 ms 128 KB
sample_03.txt AC 1 ms 128 KB
sample_04.txt AC 1 ms 128 KB
subtask_1_01.txt AC 79 ms 256 KB
subtask_1_02.txt AC 20 ms 128 KB
subtask_1_03.txt AC 7 ms 384 KB
subtask_1_04.txt AC 18 ms 384 KB
subtask_1_05.txt AC 249 ms 512 KB
subtask_1_06.txt AC 249 ms 512 KB
subtask_1_07.txt AC 30 ms 512 KB
subtask_1_08.txt AC 30 ms 512 KB
subtask_1_09.txt AC 3 ms 128 KB
subtask_1_10.txt AC 2 ms 128 KB
subtask_1_11.txt AC 1 ms 128 KB
subtask_1_12.txt AC 1 ms 128 KB
subtask_1_13.txt AC 1 ms 128 KB
subtask_1_14.txt AC 2 ms 128 KB
subtask_1_15.txt AC 1 ms 128 KB
subtask_1_16.txt AC 1 ms 128 KB
subtask_1_17.txt AC 9 ms 256 KB
subtask_1_18.txt AC 21 ms 512 KB
subtask_1_19.txt AC 1 ms 128 KB
subtask_1_20.txt AC 26 ms 512 KB
subtask_1_21.txt AC 1 ms 128 KB
subtask_1_22.txt AC 1 ms 128 KB
subtask_1_23.txt AC 1 ms 128 KB
subtask_1_24.txt AC 1 ms 128 KB
subtask_1_25.txt AC 1 ms 128 KB
subtask_1_26.txt AC 1 ms 128 KB
subtask_1_27.txt AC 1 ms 128 KB
subtask_1_28.txt AC 1 ms 128 KB
subtask_1_29.txt AC 1 ms 128 KB
subtask_1_30.txt AC 1 ms 128 KB