鱼C论坛

 找回密码
 立即注册
查看: 1449|回复: 2

这题用双指针写

[复制链接]
发表于 2023-11-17 23:12:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <bits/stdc++.h>
  2. using  namespace std;
  3. const int N=3e5;
  4. int a[N];
  5. int  main()
  6. {
  7.     int n;
  8.     cin>>n;
  9.     for(int i=1;i<=n;i++)
  10.     {
  11.         cin>>a[i];
  12.     }
  13.     int cnt=1;
  14.     for(int i=1;i<=n;i++)
  15.     {
  16.         int x=i,y=n;
  17.         while(x<y&&a[x]!=a[y])x++,y--;
  18.         cnt+=y-x;
  19.         
  20.     }
  21.     cout<<cnt<<endl;
  22. }
复制代码

不会双指针写
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-17 23:13:05 | 显示全部楼层
这段代码是一个计算数组中回文数对个数的程序。通过双指针的方法可以很好地解决这个问题。

在这段代码中,我们使用了两个指针x和y,它们分别指向数组的起始位置和末尾位置。然后我们不断地比较a[x]和a[y],如果它们不相等,则x向后移动,y向前移动,直到它们相遇为止。在这个过程中,我们可以统计出符合条件的回文数对的个数。

在这个问题中,双指针的思想是非常合适的,因为我们需要同时从数组的两端向中间靠拢,以找到所有的回文数对。这样的算法复杂度是O(n)级别的,非常高效。

希望这个解释对你有所帮助。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-17 23:13:40 | 显示全部楼层
这段代码实际上是用双指针算法来统计数组中不同的回文对的数量。下面我将稍作修改,使用双指针算法重写这段代码:
  1. #include <iostream>
  2. using namespace std;
  3. const int N = 3e5;
  4. int a[N];
  5. int main() {
  6.     int n;
  7.     cin >> n;
  8.     for (int i = 0; i < n; i++) {
  9.         cin >> a[i];
  10.     }
  11.     int cnt = 0;
  12.     for (int i = 0; i < n; i++) {
  13.         int left = i, right = n - 1;
  14.         while (left < right) {
  15.             if (a[left] == a[right]) {
  16.                 cnt++;  // 找到一个回文对
  17.             }
  18.             left++;
  19.             right--;
  20.         }
  21.     }
  22.     cout << cnt << endl;
  23.     return 0;
  24. }
复制代码

在这段代码中,我们使用了两个指针 leftright 分别指向数组中的元素,然后向中间移动这两个指针来寻找回文对。每当找到一个回文对时,就将计数器 cnt 增加 1。这样就能统计出数组中不同的回文对的数量。

希望这次修改后的代码能够满足你的需求。如果有其他问题或需要进一步解释,请随时提出。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-21 15:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表