鱼C论坛

 找回密码
 立即注册
查看: 1060|回复: 3

[已解决]怎么在冒泡排序法里边加一个计数器,计算比较次数

[复制链接]
发表于 2020-1-16 19:12:34 | 显示全部楼层 |阅读模式
20鱼币
想在if里面加个计数器最后输出比较次数,但不知道计数器该咋写,大佬们帮帮忙!
  1. #include <stdio.h>
  2. int number[10000000];

  3. int main()     
  4. {
  5.     int i,n,k,j,temp;
  6.     scanf("%d",&n);   
  7.     for(j=0;j<n;j++)
  8.         scanf("%d",&number[j]) ;
  9.     for (j=0;j<n-1;j++)   
  10.     {                           
  11.         for (k=0;k<n-1-j;k++)
  12.         {
  13.             if(number[k]>number[k+1])
  14.             {
  15.                 temp=number[k];
  16.                 number[k]=number[k+1];   
  17.                 number[k+1]=temp;
  18.             }
  19.         }
  20.     }
  21.     for (i=0;i<n-1;i++)
  22.     printf("%d ",number[i]);                           
  23.     printf("%d\n",number[i]);
  24.     //最后在这输出比较次数
  25.     return 0;
  26. }
复制代码
最佳答案
2020-1-16 19:12:35
  1. #include <stdio.h>
  2. int number[10000000];

  3. int main()     
  4. {
  5.     int i,n,k,j,temp;
  6.     size_t count = 0;
  7.     scanf("%d",&n);   
  8.     for(j=0;j<n;j++)
  9.         scanf("%d",&number[j]) ;
  10.     for (j=0;j<n-1;j++)   
  11.     {                           
  12.         for (k=0;k<n-1-j;k++)
  13.         {
  14.             if(number[k]>number[k+1])
  15.             {
  16.                 ++count;
  17.                 temp=number[k];
  18.                 number[k]=number[k+1];   
  19.                 number[k+1]=temp;
  20.             }
  21.         }
  22.     }
  23.     for (i=0;i<n-1;i++)
  24.     printf("%d ",number[i]);                           
  25.     printf("%d\n",number[i]);
  26.     //最后在这输出比较次数
  27.     printf("%u\n", count);
  28.     return 0;
  29. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-1-16 19:12:35 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>
  2. int number[10000000];

  3. int main()     
  4. {
  5.     int i,n,k,j,temp;
  6.     size_t count = 0;
  7.     scanf("%d",&n);   
  8.     for(j=0;j<n;j++)
  9.         scanf("%d",&number[j]) ;
  10.     for (j=0;j<n-1;j++)   
  11.     {                           
  12.         for (k=0;k<n-1-j;k++)
  13.         {
  14.             if(number[k]>number[k+1])
  15.             {
  16.                 ++count;
  17.                 temp=number[k];
  18.                 number[k]=number[k+1];   
  19.                 number[k+1]=temp;
  20.             }
  21.         }
  22.     }
  23.     for (i=0;i<n-1;i++)
  24.     printf("%d ",number[i]);                           
  25.     printf("%d\n",number[i]);
  26.     //最后在这输出比较次数
  27.     printf("%u\n", count);
  28.     return 0;
  29. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-1-16 21:32:15 | 显示全部楼层
  1. #include <iostream>
  2. using namespace std;
  3. void main()
  4. {

  5.         int arr[10] = { 4,6,1,2,0,3,5,9,8,7 };
  6.         int size = sizeof(arr) / sizeof(arr[0]);
  7.         int contrastNumber = 0;

  8.         for (int i = 0; i < size - 1; i++)
  9.         {
  10.                 for (int j = 0; j < size - 1 - i; j++)
  11.                 {
  12.                         if (arr[j] > arr[j + 1])
  13.                         {
  14.                                 contrastNumber++;
  15.                                 int temp = arr[j];
  16.                                 arr[j] = arr[j + 1];
  17.                                 arr[j + 1] = temp;
  18.                         }
  19.                 }

  20.         }

  21.         cout << "排序后的顺序为:" << endl;
  22.         for (int i = 0; i < size; i++)
  23.         {
  24.                 cout << arr[i] << endl;

  25.         }
  26.         cout << "一共对比了:" << contrastNumber << "次" << endl;


  27. }

复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-1-16 22:35:46 | 显示全部楼层
#include <stdio.h>
int number[10000000];

int main()
{
    int a[]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20};
    int *p=a;
    static int aa;
    int i,n,k,j,temp;
    printf("请输入几位数;");
    scanf("%d",&n);
    printf("请输入要进行排序的整数;");
    for(j=0;j<n;j++)
     scanf("%d",&number[j]) ;
    for (j=0;j<n-1;j++)
     {
       p=a;
       printf("第%d轮",j+1);
       for (k=0;k<n-1-j;k++)
        {
         if(number[k]>number[k+1])
         {
          temp=number[k];
          number[k]=number[k+1];
          number[k+1]=temp;
          p++;
         }
        }
      aa=aa+*p;
      printf("进行交换了%d次\n",*p);
     }
    printf("排序后的结果;\n");
    for (i=0;i<n;i++)
     {
      printf("%d ",number[i]);
     nclude <stdio.h>
int number[10000000];
}
    printf("\n");
    printf("一共交换了%d次\n",aa);

    return 0;
}
                    
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-27 07:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表