首页 > 编程语言 > 详细

数据排序 第一讲( 各种排序方法 结合noi题库1.10)

时间:2017-02-19 15:20:56      阅读:462      评论:0      收藏:0      [点我收藏+]

选择排序

1.基本思想:每一趟从待排序的数据元素选出最小或最大的一个元素,数按序排放在待排序的元素的最前端,直到全部待排序的元素排完

2.基本代码

px(int r[])
{
    for(int i=1;i<n;i++)
       {
           int k=i;
           for(int j=i+1;j<=n;j++)
              {
                 if(a[k]>a[j]
                     K=J;
                }
            if(k!=i)
              {
                    int tmp=a[i];
                    a[i]=a[k];
                    a[k]=a[i];
                }
           }
}

3.例题

谁考了第k名

总时间限制: 
1000ms
 
内存限制: 
65536kB
描述

在一次考试中,每个学生的成绩都不相同,现知道了每个学生的学号和成绩,求考第k名学生的学号和成绩。

输入
第一行有两个整数,分别是学生的人数n(1≤n≤100),和求第k名学生的k(1≤k≤n)。
其后有n行数据,每行包括一个学号(整数)和一个成绩(浮点数),中间用一个空格分隔。
输出
输出第k名学生的学号和成绩,中间用空格分隔。(注:请用%g输出成绩)
样例输入
5 3
90788001 67.8
90788002 90.3
90788003 61
90788004 68.4
90788005 73.9
样例输出
90788004 68.4
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,k,a[101];
float b[101];
int main()
{
    scanf("%d%d",&n,&k);
    for(int i=1;i<=n;i++)
     {
         cin>>a[i];
         cin>>b[i];
     }
     for(int i=1;i<n;i++)
     {
         for(int j=i+1;j<=n;j++)
         {
             if(b[i]<b[j])
             {
                 float tmp=b[i];
                 b[i]=b[j];
                 b[j]=tmp;
                 int amp=a[i];
                 a[i]=a[j];
                 a[j]=amp;
             }
         }
     }
     for(int i=1;i<=n;i++)
     {
         if(i==k)
         {
          cout<<a[i]<<" ";
         printf("%.6g",b[i]);
         }
     }
     return 0;
}

冒泡排序

1.基本思想:依次比较相邻的两个数,把大的放前面小的放后面。即先比较第一个和第二个,在比较第二个和第三个。。。。。。直到比较完最后两个数,则最小的数一定在最后面

2.核心代码

    for(int i=1;i<n;i++)
       for(int j=1;j<=n-i;j++)
            {
                int tmp=a[j];
                a[j]=a[j+1];
                a[j+1]=tmp;
         } 

3.例题

02:奇数单增序列

总时间限制: 
1000ms
 
内存限制: 
65536kB
描述

给定一个长度为N(不大于500)的正整数序列,请将其中的所有奇数取出,并按升序输出。

输入
共2行:
第1行为 N;
第2行为 N 个正整数,其间用空格间隔。
输出
增序输出的奇数序列,数据之间以逗号间隔。数据保证至少有一个奇数。
样例输入
10
1 3 2 6 5 4 9 8 7 10
样例输出
1,3,5,7,9
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,l;
int a[501],b[501];
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
       {
           scanf("%d",&a[i]);
           if(a[i]%2!=0)
           {
               l++;
               b[l]=a[i];
            } 
       }
    for(int i=1;i<l;i++)
       for(int j=1;j<=l-i;j++)
            if(b[j]>b[j+1])
            {
                int tmp=b[j];
                b[j]=b[j+1];
                b[j+1]=tmp;
            } 
    for(int i=1;i<l;i++)
       printf("%d,",b[i]);
    printf("%d",b[l]);
    return 0;
 } 

结构体排序

有同学会说,不就是给结构体排序吗,这个简单,那在这就不都说了

例题

03:成绩排序

总时间限制: 
1000ms
 
内存限制: 
65536kB
描述

给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。

输入
第一行为n (0 < n < 20),表示班里的学生数目;
接下来的n行,每行为每个学生的名字和他的成绩, 中间用单个空格隔开。名字只包含字母且长度不超过20,成绩为一个不大于100的非负整数。
输出
把成绩单按分数从高到低的顺序进行排序并输出,每行包含名字和分数两项,之间有一个空格。
样例输入
4
Kitty 80
Hanmeimei 90
Joey 92
Tim 28
样例输出
Joey 92
Hanmeimei 90 
Kitty 80
Tim 28
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n;
struct student
{
    int score;
    string name;
}a[21];
int score_comp(const student &a,const student &b)
{
    if(a.score>b.score) return 1;
    if(a.score<b.score) return 0;
    if(a.name<b.name) return 1;
    return 0;
}
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        cin>>a[i].name;
        cin>>a[i].score;
    }    
    sort(a+1,a+n+1,score_comp);
    for(int i=1;i<=n;i++)
     {
         cout<<a[i].name<< ;
         cout<<a[i].score<<endl;
     }
     return 0;
}

桶排序

1.基本思想

若带排序的记录的关键词在一个明显的有限范围内(整形)时,可以设计有限个有序桶,每个桶装入一个值(当然可以装入若干个值)

顺序输出各桶的值,将得到一个有序数列。

2.模板

例题:输入n个0到100之间的整数,从小到大排序

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,k;
int b[501];
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
       {
           scanf("%d",&k);
           b[k]++;
       }
    for(int i=0;i<=100;i++)
      while(b[i]>0)
       {
           printf("%d ",i);
           b[i]--;
       }
    return 0;
 } 

3.例题

1076 排序

 

 时间限制: 1 s
 空间限制: 128000 KB
 题目等级 : 白银 Silver
 
 
 
题目描述 Description

给出n和n个整数,希望你从小到大给他们排序

输入描述 Input Description

第一行一个正整数n

 

第二行n个用空格隔开的整数

输出描述 Output Description

输出仅一行,从小到大输出n个用空格隔开的整数

样例输入 Sample Input

3

3 1 2

样例输出 Sample Output

1 2 3

数据范围及提示 Data Size & Hint

1<=n<=100000

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,k;
int b[100001];
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
       {
           scanf("%d",&k);
           b[k]++;
       }
    for(int i=0;i<=100000;i++)
      while(b[i]>0)
       {
           printf("%d ",i);
           b[i]--;
       }
    return 0;
 } 

 

数据排序 第一讲( 各种排序方法 结合noi题库1.10)

原文:http://www.cnblogs.com/z360/p/6415253.html

(1)
(1)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!