add cpps
This commit is contained in:
parent
a9704560e3
commit
2f49014fef
4
.gitignore
vendored
4
.gitignore
vendored
@ -44,4 +44,6 @@ day2/U111091/out.txt
|
|||||||
day2/U111091/fixed
|
day2/U111091/fixed
|
||||||
day4/T435167/T435167
|
day4/T435167/T435167
|
||||||
day4/U461920/U461920
|
day4/U461920/U461920
|
||||||
test.txt
|
test.txt
|
||||||
|
day4/U76034/chat
|
||||||
|
day4/U287193/chat
|
||||||
|
@ -37,6 +37,10 @@ int main(){
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Day4
|
||||||
|
### [T435167 01 Sort](./day4/T435167/T435167.md)
|
||||||
|
#### 通过异色中转
|
||||||
|
|
||||||
# 排序
|
# 排序
|
||||||
## 稳定性
|
## 稳定性
|
||||||
>隔着老远swap一般不稳定
|
>隔着老远swap一般不稳定
|
||||||
|
@ -4,9 +4,22 @@
|
|||||||
using namespace std;
|
using namespace std;
|
||||||
#define int long long
|
#define int long long
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
#define PRINT_VALUE(v){cout<<#v<<" :"<<v<<endl;}
|
||||||
|
#define PRINT_ARRAY(arr,size){cout<<#arr<<" [";for(int i=1;i<=size;i++){cout<<arr[i]<<(i!=size?",":"]\n");}}
|
||||||
|
#define DEBUG_PRINT(c){cout<<c<<endl;}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef DEBUG
|
||||||
|
#define PRINT_VALUE(v)
|
||||||
|
#define PRINT_ARRAY(arr,size)
|
||||||
|
#define DEBUG_PRINT(c)
|
||||||
|
#endif
|
||||||
|
|
||||||
const int MAX_N = 1e3+5;
|
const int MAX_N = 1e3+5;
|
||||||
int t,n;
|
int t,n;
|
||||||
int a[MAX_N],b[MAX_N];
|
int a[MAX_N],b[MAX_N];
|
||||||
|
vector<pair<int, int>> histories;
|
||||||
|
|
||||||
bool checkAllEleGoUp(){
|
bool checkAllEleGoUp(){
|
||||||
for(int i=2;i<=n;i++){
|
for(int i=2;i<=n;i++){
|
||||||
@ -17,7 +30,36 @@ bool checkAllEleGoUp(){
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void sort_fixed(){
|
||||||
|
for(int i=1;i<=n;i++){
|
||||||
|
int max_num=INT_MIN;
|
||||||
|
vector<int> max_dirs;
|
||||||
|
for (int j=i; j<=n; j++) {
|
||||||
|
if (max_num<a[j]) {
|
||||||
|
max_dirs.clear();
|
||||||
|
max_num=a[j];
|
||||||
|
max_dirs.push_back(j);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
int swap_dir=-1;
|
||||||
|
for (int j=0; i<max_dirs.size(); i++) {
|
||||||
|
if(b[max_dirs[j]]!=b[i]){
|
||||||
|
swap_dir=max_dirs[j];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (swap_dir==-1) {
|
||||||
|
histories.clear();
|
||||||
|
return;
|
||||||
|
}else {
|
||||||
|
histories.push_back(make_pair(i, swap_dir));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
signed main(){
|
signed main(){
|
||||||
|
cin.sync_with_stdio(false);
|
||||||
|
cin.tie(0);
|
||||||
cin>>t;
|
cin>>t;
|
||||||
for(int i=1;i<=t;i++){
|
for(int i=1;i<=t;i++){
|
||||||
bool isAllBZero=true;
|
bool isAllBZero=true;
|
||||||
@ -40,6 +82,15 @@ signed main(){
|
|||||||
cout<<-1<<endl;
|
cout<<-1<<endl;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
cout<<0<<endl;
|
sort_fixed();
|
||||||
|
if (histories.size()==0) {
|
||||||
|
PRINT_VALUE(histories.size());
|
||||||
|
cout<<-1<<endl;
|
||||||
|
}else {
|
||||||
|
cout<<histories.size()<<endl;
|
||||||
|
for (auto v : histories) {
|
||||||
|
cout<<v.first<<" "<<v.second<<endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
66
day4/U287193/chat.cpp
Normal file
66
day4/U287193/chat.cpp
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
#include <bits/stdc++.h>
|
||||||
|
using namespace std;
|
||||||
|
const int MOD = 998244353;
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
#define PRINT_VALUE(v){cout<<#v<<" :"<<v<<endl;}
|
||||||
|
#define PRINT_ARRAY(arr,size){cout<<#arr<<" [";for(int i=1;i<=size;i++){cout<<arr[i]<<(i!=size?",":"]\n");}}
|
||||||
|
#define DEBUG_PRINT(c){cout<<c<<endl;}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef DEBUG
|
||||||
|
#define PRINT_VALUE(v)
|
||||||
|
#define PRINT_ARRAY(arr,size)
|
||||||
|
#define DEBUG_PRINT(c)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
int n, m;
|
||||||
|
cin >> n >> m;
|
||||||
|
vector<int> lim(n);
|
||||||
|
for (int i = 0; i < n; ++i) {
|
||||||
|
cin >> lim[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
vector<vector<int>> dp(n + 1, vector<int>(m + 1, 0));
|
||||||
|
dp[0][0] = 1;
|
||||||
|
|
||||||
|
vector<int> positions;
|
||||||
|
for (int i = 1; i <= n; ++i) {
|
||||||
|
if (lim[i - 1] == 0) {
|
||||||
|
positions.push_back(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int total_permutations = 1;
|
||||||
|
for (int i = 1; i <= positions.size(); ++i) {
|
||||||
|
total_permutations = (total_permutations * i) % MOD;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 1; i <= n; ++i) {
|
||||||
|
if (lim[i - 1] != 0) {
|
||||||
|
for (int j = 0; j <= m; ++j) {
|
||||||
|
dp[i][j] = dp[i - 1][j];
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (int j = 0; j <= m; ++j) {
|
||||||
|
for (int k = 0; k < i; ++k) {
|
||||||
|
if (j - k >= 0) {
|
||||||
|
dp[i][j] = (dp[i][j] + dp[i - 1][j - k]) % MOD;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int result = 0;
|
||||||
|
for (int j = 0; j <= m; ++j) {
|
||||||
|
result = (result + dp[n][j]) % MOD;
|
||||||
|
}
|
||||||
|
|
||||||
|
result = (result * total_permutations) % MOD;
|
||||||
|
|
||||||
|
cout << result << endl;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@ -25,6 +25,8 @@ void set_num_times_mem(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
int main(){
|
int main(){
|
||||||
|
cin.sync_with_stdio(false);
|
||||||
|
cin.tie(0);
|
||||||
cin>>n;
|
cin>>n;
|
||||||
set_num_times_mem();
|
set_num_times_mem();
|
||||||
PRINT_ARRAY(num_times,n);
|
PRINT_ARRAY(num_times,n);
|
||||||
|
4
day4/U76034/1.in
Normal file
4
day4/U76034/1.in
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
3
|
||||||
|
6 3
|
||||||
|
4 2
|
||||||
|
1244 1241
|
92
day4/U76034/chat.cpp
Normal file
92
day4/U76034/chat.cpp
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
#include <iostream>
|
||||||
|
#include <vector>
|
||||||
|
#include <map>
|
||||||
|
#include <cmath>
|
||||||
|
#define MOD 1000000007
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
#define PRINT_VALUE(v){cout<<#v<<" :"<<v<<endl;}
|
||||||
|
#define PRINT_ARRAY(arr,size){cout<<#arr<<" [";for(int i=1;i<=size;i++){cout<<arr[i]<<(i!=size?",":"]\n");}}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef DEBUG
|
||||||
|
#define PRINT_VALUE(v)
|
||||||
|
#define PRINT_ARRAY(arr,size)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef long long ll;
|
||||||
|
|
||||||
|
ll power(ll a, ll b, ll mod) {
|
||||||
|
ll res = 1;
|
||||||
|
while (b > 0) {
|
||||||
|
if (b % 2 == 1)
|
||||||
|
res = (res * a) % mod;
|
||||||
|
a = (a * a) % mod;
|
||||||
|
b /= 2;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
map<ll, ll> prime_factorization(ll x) {
|
||||||
|
map<ll, ll> factors;
|
||||||
|
for (ll i = 2; i * i <= x; ++i) {
|
||||||
|
while (x % i == 0) {
|
||||||
|
factors[i]++;
|
||||||
|
x /= i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (x > 1) {
|
||||||
|
factors[x]++;
|
||||||
|
}
|
||||||
|
return factors;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
ios::sync_with_stdio(false);
|
||||||
|
cin.tie(0);
|
||||||
|
|
||||||
|
int q;
|
||||||
|
cin >> q;
|
||||||
|
vector<pair<ll, ll>> queries(q);
|
||||||
|
|
||||||
|
for (int i = 0; i < q; ++i) {
|
||||||
|
cin >> queries[i].first >> queries[i].second;
|
||||||
|
}
|
||||||
|
|
||||||
|
const int MAXN = 1e6 + 5;
|
||||||
|
vector<ll> fact(2 * MAXN), invFact(2 * MAXN);
|
||||||
|
|
||||||
|
fact[0] = 1;
|
||||||
|
for (int i = 1; i < 2 * MAXN; ++i) {
|
||||||
|
fact[i] = fact[i - 1] * i % MOD;
|
||||||
|
}
|
||||||
|
invFact[2 * MAXN - 1] = power(fact[2 * MAXN - 1], MOD - 2, MOD);
|
||||||
|
for (int i = 2 * MAXN - 2; i >= 0; --i) {
|
||||||
|
invFact[i] = invFact[i + 1] * (i + 1) % MOD;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto binomial = [&](ll n, ll k) {
|
||||||
|
if (n < k) return 0LL;
|
||||||
|
return fact[n] * invFact[k] % MOD * invFact[n - k] % MOD;
|
||||||
|
};
|
||||||
|
|
||||||
|
for (auto [x, n] : queries) {
|
||||||
|
if (n == 1) {
|
||||||
|
cout << (x == 1 ? 1 : 2) << '\n';
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
map<ll, ll> factors = prime_factorization(x);
|
||||||
|
ll result = 1;
|
||||||
|
|
||||||
|
for (auto [p, e] : factors) {
|
||||||
|
result = result * binomial(2 * n + e - 1, e) % MOD;
|
||||||
|
}
|
||||||
|
|
||||||
|
cout << result << '\n';
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user