洛谷-算法1-1-模拟与高精度2
P1303 A*B Problem题目背景高精度乘法模板题。题目描述给出两个非负整数求它们的乘积。输入格式输入共两行每行一个非负整数。输出格式输出一个非负整数表示乘积。输入输出样例输入 #1复制1 2输出 #1复制2说明/提示每个非负整数不超过 102000。实现代码#includebits/stdc.h using namespace std; #define int long long const int N5e7; char a[N],b[N]; int s[N]; signed main(){ cina1; cinb1; int s1strlen(a1); int s2strlen(b1); reverse(a1,a1s1); reverse(b1,b1s2); int t0; for(int i1;is1;i){ for(int j1;js2;j){ s[ij-1](a[i]-0)*(b[j]-0)t; ts[ij-1]/10; s[ij-1]s[ij-1]%10; } int lenis2; if(t0){ s[len]t; t0; } } int f0; if(s[s1s2]0){ for(int is1s2-1;i1;i--){ if((s[i]!0)||(s[i]0f1)){ couts[i]; f1; } } if(f0){ cout0; } } else{ for(int is1s2;i1;i--){ couts[i]; } } return 0; }P1009 [NOIP 1998 普及组] 阶乘之和题目描述用高精度计算出 S1!2!3!⋯n!n≤50。其中!表示阶乘定义为 n!n×(n−1)×(n−2)×⋯×1。例如5!5×4×3×2×1120。输入格式一个正整数 n。输出格式一个正整数 S表示计算结果。输入输出样例输入 #1复制3输出 #1复制9说明/提示【数据范围】对于 100% 的数据1≤n≤50。【其他说明】注《深入浅出基础篇》中使用本题作为例题但是其数据范围只有 n≤20使用书中的代码无法通过本题。如果希望通过本题请继续学习第八章高精度的知识。NOIP1998 普及组 第二题实现代码#includebits/stdc.h using namespace std; #define int long long const int N111; int a[N]{0},s[N]{0}; int n; void fun(int x){ int t0; for(int i100;i1;i--){ a[i]a[i]*xt; ta[i]/10; a[i]a[i]%10; } } void f(){ int t0; for(int i100;i1;i--){ s[i]a[i]t; ts[i]/10; s[i]s[i]%10; } } signed main(){ cinn; a[100]1; for(int i1;in;i){ fun(i); f(); } for(int i1;i100;i){ if(s[i]){ for(int ji;j100;j){ couts[j]; } return 0; } } return 0; }P4924 [1007] 魔法少女小Scarlet题目描述Scarlet 最近学会了一个数组魔法她会在 n×n 二维数组上将一个奇数阶方阵按照顺时针或者逆时针旋转 90∘。首先Scarlet 会把 1 到 n2 的正整数按照从左往右从上至下的顺序填入初始的二维数组中然后她会施放一些简易的魔法。Scarlet 既不会什么分块特技也不会什么 Splay 套 Splay她现在提供给你她的魔法执行顺序想让你来告诉她魔法按次执行完毕后的二维数组。输入格式第一行两个整数 n,m表示方阵大小和魔法施放次数。接下来 m 行每行 4 个整数 x,y,r,z表示在这次魔法中Scarlet 会把以第 x 行第 y 列为中心的 2r1 阶矩阵按照某种时针方向旋转其中 z0 表示顺时针z1 表示逆时针。输出格式输出 n 行每行 n 个用空格隔开的数表示最终所得的矩阵。输入输出样例输入 #1复制5 4 2 2 1 0 3 3 1 1 4 4 1 0 3 3 2 1输出 #1复制5 10 3 18 15 4 19 8 17 20 1 14 23 24 25 6 9 2 7 22 11 12 13 16 21说明/提示对于 50% 的数据满足 r1对于 100% 的数据满足 1≤n,m≤5001≤x−r≤xr≤n1≤y−r≤yr≤n。实现代码#includebits/stdc.h using namespace std; int g[510][510],tot,f[510][510]; int main(){ int n,m; scanf(%d %d,n,m); for(int i1;in;i) for(int j1;jn;j) g[i][j]tot; for(int i1;im;i) { int a,b,r,opt; scanf(%d %d %d %d,a,b,r,opt); if(opt0) { for(int ia-r;iar;i) for(int jb-r;jbr;j) f[a-bj][ab-i] g[i][j]; for(int ia-r;iar;i) for(int jb-r;jbr;j) g[i][j] f[i][j]; } else { for(int ia-r;iar;i) for(int jb-r;jbr;j) f[ab-j][b-ai] g[i][j]; for(int ia-r;iar;i) for(int jb-r;jbr;j) g[i][j] f[i][j]; } } for(int i1;in;i) { for(int j1;jn;j) printf(%d ,g[i][j]); printf(\n); } return 0; }P1328 [NOIP 2014 提高组] 生活大爆炸版石头剪刀布题目背景NOIP2014 提高组 D1T1题目描述石头剪刀布是常见的猜拳游戏石头胜剪刀剪刀胜布布胜石头。如果两个人出拳一样则不分胜负。在《生活大爆炸》第二季第 8 集中出现了一种石头剪刀布的升级版游戏。升级版游戏在传统的石头剪刀布游戏的基础上增加了两个新手势斯波克:《星际迷航》主角之一。蜥蜴人:《星际迷航》中的反面角色。这五种手势的胜负关系如表一所示,表中列出的是甲对乙的游戏结果。现在小 A 和小 B 尝试玩这种升级版的猜拳游戏。已知他们的出拳都是有周期性规律的但周期长度不一定相等。例如如果小 A 以石头-布-石头-剪刀-蜥蜴人-斯波克长度为 6 的周期出拳,那么他的出拳序列就是石头-布-石头-剪刀-蜥蜴人-斯波克-石头-布-石头-剪刀-蜥蜴人-斯波克-...而如果小 B 以剪刀-石头-布-斯波克-蜥蜴人长度为 5 的周期出拳,那么他出拳的序列就是剪刀-石头-布-斯波克-蜥蜴人-剪刀-石头-布-斯波克-蜥蜴人-...。已知小 A 和小 B 一共进行 N 次猜拳。每一次赢的人得 1 分输的得 0 分平局两人都得 0 分。现请你统计 N 次猜拳结束之后两人的得分。输入格式第一行包含三个整数N,NA,NB分别表示共进行 N 次猜拳、小 A 出拳的周期长度小 B 出拳的周期长度。数与数之间以一个空格分隔。第二行包含 NA 个整数,表示小 A 出拳的规律,第三行包含 NB 个整数表示小 B 出拳的规律。其中0 表示剪刀1 表示石头2 表示布3 表示蜥蜴人4 表示斯波克。数与数之间以一个空格分隔。输出格式输出一行包含两个整数以一个空格分隔分别表示小 A、小 B 的得分。输入输出样例输入 #1复制10 5 6 0 1 2 3 4 0 3 4 2 1 0输出 #1复制6 2输入 #2复制9 5 5 0 1 2 3 4 1 0 3 2 4输出 #2复制4 4说明/提示对于 100% 的数据0N≤200,0NA≤200,0NB≤200 。实现代码#include iostream using namespace std; int n, a, b, p[205],q[205], x, y; int k[5][5] {{0, 0, 1, 1, 0}, {1, 0, 0, 1, 0}, {0, 1, 0, 0, 1}, {0, 0, 1, 0, 1}, {1, 1, 0, 0, 0}}; int main() { cin n a b; for (int i 0; i a; i) cin p[i]; for (int i 0; i b; i) cin q[i]; for (int i 0; i n; i) { x k[p[i % a]][q[i % b]]; y k[q[i % b]][p[i % a]]; } cout x y; return 0; }