kkkkk


私信TA

用户名:kkkkk

访问量:4126

签 名:

等  级
排  名 2051
经  验 1261
参赛次数 2
文章发表 9
年  龄 0
在职情况 学生
学  校 安徽财经大学
专  业

  自我简介:

TA的其他文章

解题思路:

通过插入的数cr的和数组元素a[i]的差值的绝对值的最小值,来实现插入的数的打印位置。



注意事项:这种算法有bug,只能保证本题的结果是对的,当abs(cr-a[i])>=abs(cr-a[i+1])就重复打印ar了,有同学帮我优化一下吗?





参考代码:

#include<stdio.h>
#include<math.h>
int main()
{
	int a[9],min;  //min是插入的cr和数组元素的a[i]的绝对值的最小数 
	int cr,i;
	for(i=0;i<9;i++)
    scanf("%d",&a[i]);
    scanf("%d",&cr);
    min=abs(a[0]-cr);  //对min进行初始赋值
	for(i=0;i<9;i++)   //找出最小值
	{ 
	    if(abs(a[i]-cr)>=abs(a[i+1]-cr))
		continue;	
		if(abs(a[i]-cr)<min)
		min=abs(a[i]-cr);
	}   
	    for(i=0;i<9;i++)
	  {
		printf("%d\n",a[i]);
		if(abs(a[i+1]-cr)==min)
		printf("%d\n",cr);
           }
	return 0;
 }


 

0.0分

0 人评分

  评论区