小米oj记录——(四十八)找数字对

描述

有一串可能含重复数字的列表,例如 N = {4,13,5,6,35,85,3},对于任意 A ∈ N,B ∈ N, 使 A+B = 10 或 |A-B| = 10; 即两数之合为 10 或两数之差的绝对值为 10。

找出所有满足条件的数字对 {A,B} 的个数。(A, B的顺序与原始数组保持一致)

输入

一行文本由英文逗号分隔,如 6,4,16

输出

2

输入样例

4,13,5,6,35,85,3
13,3,6,8,12,4,45,56,66,16
6,4,16

输出样例

2
4
2

代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stddef.h>
#include <ctype.h>

int main()
{
	int i,j,m,n=0,a[1000];
	for(i=0;i<1000;i++)
	{
		scanf("%d",&a[i]);
		if(getchar()!=',')
			break;
	}
	for(j=0;j<i;j++)
	{
		for(m=j+1;m<=i;m++)
			if(a[j]+a[m]==10||abs(a[j]-a[m])==10)
				n++;
	}
	printf("%d",n);
}

心得

  1. 求绝对值用函数 abs()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值