用冒泡排序法对输入的10个数进行降序排序并存入数组中,然后输入一个数,查找该数是否在数组中

用C语言解答... 用C语言解答 展开
 我来答
DoramiHe
2018-06-01 · 知道合伙人互联网行家
DoramiHe
知道合伙人互联网行家
采纳数:25335 获赞数:59535
2011年中山职业技术学院毕业,现担任毅衣公司京东小二

向TA提问 私信TA
展开全部
int main(void)
{
int i,j,array[20],temp;
printf("Input 20 integer:"); /*输入20个整数*/
for(i=0;i<20;i++)
scanf("%d",&array[i]);
printf("\n");
for(i=0;i<20;i++) /*用双重循环,冒泡法排序*/
for(j=i;j<20;j++)
if(array[i]<array[j])
{temp=array[i];array[i]=array[j];array[j]=temp;}
for(i=0;i<20;i++) /*输出排序后的数组元素*/
printf("%d\t",array[i]);
printf("\nInput integer:"); /*输入一个整数*/
scanf("%d",&temp);
for(i=0;i<20&&temp<=array[i];i++) /*在排序后的数组中查找*/
if(temp==array[i])
printf("array[%d] is needed.\n",i); /*在数组中有可能有相等的元素*/
if(temp!=array[i-1])
printf("array[] have not the integer.");/*数组中没有所输入的数*/
getch();
return 0;
}
程序运行结果:
Input 20 integer:1 2 3 4 5 66 77 33 22 33 4 66 4 8 7 6 55 33 222 20

222 77 66 66 55 33 33 33 22 20
8 7 6 5 4 4 4 3 2 1

Input integer:4
array[14] is needed.
array[15] is needed.
array[16] is needed.
锐青旋7654
2011-06-25 · TA获得超过167个赞
知道答主
回答量:463
采纳率:100%
帮助的人:261万
展开全部
int main(void)
{
int i,j,array[20],temp;
printf("Input 20 integer:"); /*输入20个整数*/
for(i=0;i<20;i++)
scanf("%d",&array[i]);
printf("\n");
for(i=0;i<20;i++) /*用双重循环,冒泡法排序*/
for(j=i;j<20;j++)
if(array[i]<array[j])

for(i=0;i<20;i++) /*输出排序后的数组元素*/
printf("%d\t",array[i]);
printf("\nInput integer:"); /*输入一个整数*/
scanf("%d",&temp);
for(i=0;i<20&&temp<=array[i];i++) /*在排序后的数组中查找*/
if(temp==array[i])
printf("array[%d] is needed.\n",i); /*在数组中有可能有相等的元素*/
if(temp!=array[i-1])
printf("array[] have not the integer.");/*数组中没有所输入的数*/
getch();
return 0;
}
程序运行结果:
Input 20 integer:1 2 3 4 5 66 77 33 22 33 4 66 4 8 7 6 55 33 222 20

222 77 66 66 55 33 33 33 22 20
8 7 6 5 4 4 4 3 2 1

Input integer:4
array[14] is needed.
array[15] is needed.
array[16] is needed.
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
returnsr
2011-06-24 · TA获得超过296个赞
知道小有建树答主
回答量:271
采纳率:0%
帮助的人:162万
展开全部
#include <stdio.h>

#define LEN 10

void ReadNumber(int *num)
{
int i;
for (i=0; i<LEN; i++)
{
scanf("%d", &num[i]);
}
}

void Sort(int *num)
{
int i, j;
int single, temp;
for(i=LEN; i>0; i--)
{
single = 0;
for (j=0; j<LEN-1; j++)
{
if (num[j]<num[j+1])
{
temp = num[j];
num[j] = num[j+1];
num[j+1] = temp;
single = 1;
}

}
if (single == 0)
{
break;
}
}

}

int find(int *num, int CheckNumber)
{
int i=0;
while(i<LEN)
{
if ( num[i] == CheckNumber)
{
return i+1;
}
i++;
}
return 0;
}

void main()
{
int num[LEN];
// int i;
ReadNumber(num);
// for(i=0; i<LEN; i++)
// {
// printf("%d", num[i]);
// }
Sort(num);
// putchar(10);
// for(i=0; i<LEN; i++)
// {
// printf("%d", num[i]);
// }
// putchar(10);
// i=0;
// if (i = find(num, 3))
// {
// printf("%d", i);
// }
find(num, 4);

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式