上一页 1 ··· 13 14 15 16 17 18 19 20 21 ··· 67 下一页
摘要: 思路 思路同k倍区间。 前缀积得到每个点的正负。枚举右端点$r$,统计满足$s[r]$和$s[l-1]$同号的左端点$l$的数目,$s[r]$和$s[l-1]$同号则$s[l \sim r]$为正。$s[l \sim r]$为负的区间数量同理。 const int N=2e5+10; int a[N 阅读全文
posted @ 2021-05-27 12:29 Dazzling! 阅读(46) 评论(0) 推荐(0)
摘要: 数字本身为质数,且其所有前缀数字均为质数。 思路 枚举每一位 首位只能从${2,3,5,7}$选取 其余位只能从${1,3,5,7}$中选取 int n; bool isprime(int x) { if(x < 2) return false; for(int i=2;i*i<=x;i++) if 阅读全文
posted @ 2021-05-26 19:41 Dazzling! 阅读(57) 评论(0) 推荐(0)
摘要: 思路一 筛出$10^7$以内素数 判断素数表中的数是否为回文数 注意点 如果一个回文数的位数是偶数,则它的奇数位上的数字和与偶数位上的数字和必然相等,这样的数能被11整除,不可能是素数(11自己除外)。 由上条性质,素数表只要筛到$10^7$即可。 USACO上提交居然MLE?遂放弃记录素数表,直接 阅读全文
posted @ 2021-05-26 15:59 Dazzling! 阅读(133) 评论(0) 推荐(0)
摘要: 思路 将$32$位二进制数转换为十进制数,用long long存储$n+1$和$n+3$的结果(不超过$33$位),再将结果转成二进制即可。 void solve(LL n) { for(int i=32;i>=0;i--) { int t=n>>i & 1; if(i == 32 && !t) c 阅读全文
posted @ 2021-05-25 21:27 Dazzling! 阅读(36) 评论(0) 推荐(0)
摘要: 经典问题,直接暴搜出所有方案即可。 const int N=25; bool vis[N][N][N]; int a,b,c; vector<int> ans; void dfs(int x,int y,int z) { if(vis[x][y][z]) return; vis[x][y][z]=t 阅读全文
posted @ 2021-05-25 09:36 Dazzling! 阅读(27) 评论(0) 推荐(0)
摘要: 预处理出双平方数集合 枚举双平方数中的一对数作为等差数列的首项和第二项 剪枝: 计算出当前等差数列的末项,last=x+(n-1)*d比双平方数集合中最大的数还要大,则无需判断其是否能构成长度为$n$的等差数列。 如果当前公差比双平方数集合中最大的数还要大,那么比当前公差还要大的公差显然也没有枚举的 阅读全文
posted @ 2021-05-24 19:46 Dazzling! 阅读(72) 评论(0) 推荐(0)
摘要: 将$1 \sim n^2$放置在$n\times n$的棋盘当中,要求当前格子中的数字与其四连通的格子中的数字不相邻。 考虑将当前格子染成黑色,与其四连通的格子染成白色,即下标$(i,j)$的格子,当$i+j$为偶数时染成黑色,$i+j$为奇数时染成白色,则颜色不同的格子中的数字不能相邻。 按从左至 阅读全文
posted @ 2021-05-24 12:53 Dazzling! 阅读(62) 评论(0) 推荐(0)
摘要: 统计满足$i<j$并且$a_j-a_i=j-i$的数对的数量。 变形,\(a_j-j=a_i-i\)。 开哈希表,对原数组扫描一遍即可。 const int N=2e5+10; int a[N]; int n; int main() { int T; cin>>T; while(T--) { cin 阅读全文
posted @ 2021-05-24 12:36 Dazzling! 阅读(51) 评论(0) 推荐(0)
摘要: 货仓选址变形题。 将所有星号聚拢到中间的星号上,总花费最小。 移动每个星号的花费是其与中间星号间的距离并减去二者之间的星号数量。 const int N = 1e6+10; char s[N]; int a[N]; int n; int main() { int T; cin >> T; while 阅读全文
posted @ 2021-05-24 12:30 Dazzling! 阅读(37) 评论(0) 推荐(0)
摘要: 模拟。 string s,t; int m; int main() { cin>>s>>m; while(m--) { string op; cin>>op; if(op == "COPY") { int l,r; cin>>l>>r; t=s.substr(l,r-l+1); } else if( 阅读全文
posted @ 2021-05-23 19:37 Dazzling! 阅读(56) 评论(0) 推荐(0)
上一页 1 ··· 13 14 15 16 17 18 19 20 21 ··· 67 下一页