已知一个集合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);
}