私信TA

用户名:1678463512

访问量:7814

签 名:

等  级
排  名 2793
经  验 2159
参赛次数 0
文章发表 20
年  龄 20
在职情况 待业
学  校 秋长中学
专  业

  自我简介:

解题思路:

原理:遍历和交换

如    16 25 9 90 23

第一轮循环,某个数字大于后面的数字就进行交换

1, 16 25 9 90 23

2, 16 9 25 90 23

3, 19 9 25 90 23

4, 16 9 25 23 90这样 ,最大的数字就冒到了最后

所以:1,需要比较数组长度-1轮--外层循环

          2,每一轮比较的次数比上一轮-1次(内层循环控制每轮的次数)(数组长度-1)-当前的轮数

注意事项:

参考代码:

int nums[10];

    int i,temp,result,j;

    for(i = 0;i < 10;i++)

    {

        result = scanf("%d",&nums[i]);

        while(result != 1)//如果用户的输入不为数字类型

        {

            scanf("%*s");

            result = scanf("%d",&nums[i]);

        }

    }

    for(i = 0;i < 10 - 1;i++)//需要比较数组长度-1轮

    {

        for(j = 0;j < 10 - i - 1;j++)//每轮比较数组长度-i-1次

        {

            if(nums[j] > nums[j+1])//如果数组中前面一个元素大于后面一个元素,就进行交换

            {

                temp = nums[j];

                nums[j] = nums[j+1];

                nums[j+1] = temp;

            }

        }

    }

    for(i = 0;i < 10;i++)

    {

        printf("%d\n",nums[i]);

    }






第二种:指针

int a[10];

    int *p = a;//p指向了数组的首元素

    int i,temp,j;

    for(i = 0;i < 10;i++)

        scanf("%d",p+i);//数组赋值

    for(i = 0;i < 9;i++)

    {

        for(j = 0;j < 10 - i - 1;j++)

        {

            if(*(p+j) > *(p+j+1))

               {//交换

                  temp = *(p+j);

                  *(p+j)= *(p+j+1);

                  *(p+j+1) = temp;

               }

        }

    }


    for(i = 0;i < 10;i++)

        printf("%d\n",*(p+i));


 

0.0分

0 人评分

新上线《蓝桥杯辅导》课程,近五年的蓝桥杯省赛与国赛真题都有,从读题开始理解题意、梳理思路、实现代码再提交评测全过程,可有效提升获奖比例甚至进国赛!课程介绍、试听请猛击这里

  评论区

  • «
  • »