麻烦大佬看看为什么我写的程序结果不对?

已知一个集合A,对A中任意两个不同的元素求和,若求得的和仍在A内,则称其为好数对。例如,集合A={1 2 3 4},1+2=3,1+3=4,则1,2和1,3 是两个好数对。编写程序求给定集合中好数对的个数。

注:集合中最多有1000个元素,元素最大不超过10000

 

程序运行示例1:

4↙

1 2 3 4↙

2

 

程序运行示例2:

7↙

2456 3251 654 890 100 754 1234↙

1

#include<stdio.h>
int main()
{
  int n;
  
  scanf("%d",&n);
  int a[n];
  for(int i=0;i<n;i++)
{
   scanf("%d ",&a[i]);
}
int cout=0;
for(int i=0;i<n;i++)

   for(int j=i+1;j<n;j++)
     {
         if(a[i]+a[j]==a[j+1])
             {cout++;}
     }
}
printf("%d",cout);
}

 

代码修改如下,如有帮助,请采纳一下,谢谢。

#include <stdio.h>
#include <stdlib.h>
int main()
{
	int n,i,j,t;
	
	scanf("%d",&n);
	int* a = (int*)malloc(n*sizeof(int));
	for(i=0;i<n;i++)
	{
		scanf("%d",&a[i]);
	}
	int cout=0;
	for( i=0;i<n;i++)
	{ 
		for( j=i+1;j<n;j++)
		{
			for(t = 0; t <n;t++)
				if(a[i]+a[j]==a[t])
					cout++;
		}
	}
	printf("%d",cout);
	free(a);
	return 0;
}

 

#include<stdio.h>
int main()
{
    int n;
    scanf("%d",&n);
    int a[n];

    for(int i=0;i<n;i++) {
        scanf("%d ",&a[i]);
    }

    int cout=0;

    for(int i=0;i<n;i++) { 
        for(int j=i+1;j<n;j++) {
            if(a[i] + a[j] == a[j+1]) { // 逻辑实现错误,此处要遍历数组
                cout++;
            }
        }
    }
    printf("%d",cout);
}

////////////////////////////////请参考
#include<stdio.h>
int main()
{
    int hash[10001] // 哈希校验,用于查询元素是否存在,以元素值为索引

    int n;
    scanf("%d",&n);
    int a[n];

    memset(hash, 0, sizeof(hash)); // 初始化全0

    for(int i=0;i<n;i++) {
        scanf("%d ",&a[i]);
        hash[a[i]] = 1;
    }

    int cout=0;

    for(int i=0;i<n;i++) { 
        for(int j=i+1;j<n;j++) {
            int temp = a[i] + a[j];
            if (temp > 10000) {
                continue;
            }

            if(hash[temp]) { // hash校验
                cout++;
            }
        }
    }
    printf("%d",cout);
}