关于#c++#的问题:找不到错误,下面是我自己的码,需用#include <bits>

我在做题时提交后发现分值永远是50(满分100)下面是题目
传说CHGCHG是一个数学天才。在他五岁那年,从一堆数字卡片中选出了4张 卡片:5,7,6,8。这4个数字有什么神秘之处呢?如果把这4张卡片自左往右的排成:5,6,7,8,。

你就会发现:原来这4个数字构成了等差数列!当年CHG选出了n组卡片,据说都能够构成等差数列。但是事实真的是这样吗?CHG真的有这么神奇吗? n组数据就是CHG选出的n组卡片,请你判断每一组卡片是否能构成等差数列.

输入格式

第一个数为数据的组数n,表示后面有n行,每行中的第一个数为该组数据的元素个数m(1≤m≤100),其后是m个正整数(不会超出int的表示范围)。
######输出格式
如果能够构成等差数列,输出“yes”,否则输出“no”。

下面是我的代码 ()
#include <bits/stdc++.h>
using namespace std;
int n,m,a[110],c;
int main(){
cin>>n;
for (int i=1;i<=n;i++){
int q=0;
cin>>m;
a[1]=m;
for(int i=2;i<=m+1;i++){
    cin>>m;
    a[i]=m;
}
m=a[1] ;
for(int i=1;i<m;i++){
    if(a[i]>a[i+1]){
        c=a[i];
        a[i]=a[i+1];
        a[i+1]=c;
    }
}
for(int i=1;i<m;i++){
    if(a[i]+1!=a[i+1]) q=1;
}
if(q==0) cout<<"yes\n";
else cout<<"no";
}
return 0; 
}
 

######求解

1.等差数列可以间隔不为1,例如2,4,6,8也是等差数列
2.你冒泡排序只有一重循环,只能做到将最大的移到最右边

#include <iostream>
#include <algorithm>

int main()
{
    int m, n, a[100];
    std::cin >> n;
    for (int i = 0; i < n; i++)
    {
        std::cin >> m;
        for (int j = 0; j < m; j++)
            std::cin >> a[j];
        std::sort(a, a + m);
        int r = 1;
        for (int j = 0; j < m - 2; j++)
        {
            if (a[j + 2] - a[j + 1] != a[j + 1] - a[j])
            {
                r = 0;
                break;
            }
        }
        if (r)
            printf("yes\n");
        else
            printf("no\n");
    }
}