杨辉三角形求组合数问题 原题点这里 #include <iostream> #include <cmath> using namespace std; long long a[3100][3100]; int f[3100][3100]; int n,m,t,k; int main() { cin>>t>>k; a[1][1]=a[2][1]=a[2][2]=1; for(int i=3;i<=3000;i++) for(int j=1;j<=i…
一道有趣的题目,首先想到合并果子,然而发现会超时,我们可以发现首先拿出来的切掉后比后拿出来切掉后还是还长,即满足单调递增,故建立三个队列即可. 代码 #include<bits/stdc++.h> #define p u/v using namespace std; long long n,m,len,t,a,u,v; const int maxn=1e7+10; int line1[maxn],line2[maxn],line3[maxn]; int l1,l2,l3,r1,r2,r3; b…
Day 1 >>> T1 >> 水题直接模拟AC: 考察三个知识点:1.你能不能编程 2.你会不会取模 3.你脑子抽不抽 然而第一次评测还是90,因为当模运算时 “ end == 0 ” 时需要将 end 改成 n: 代码: #include <bits/stdc++.h> ; int n , k , x , y , end ; struct node { int id , face ; ] ; } m [ N ] ; int main ( ) { scanf (…