`
SunnyYoona
  • 浏览: 366950 次
社区版块
存档分类
最新评论

庞果网之数组排序

 
阅读更多

题目详情

本题来自caopengcs,只要你有兴趣,每个人都可以出题(出题入口在主页右侧边栏“贡献题目”->“我要发布”内),以下是题目详情:

给定一个包含1-n的数列,我们通过交换任意两个元素给数列重新排序。求最少需要多少次交换,能把数组排成按1-n递增的顺序,其中,数组长度不超过100。

例如:

原数组是3,2,1, 我们只需要交换1和3就行了,交换次数为1,所以输出1。

原数组是2,3,1,我们需要交换2和1,变成1,3,2,再交换3和2,变为1,2,3,总共需要的交换次数为2,所以输出2。


/*********************************
*   日期:2013-11-03
*   作者:SJF0115
*   题号: 题目 数组排序
*   来源:http://hero.pongo.cn/Question/Details?ID=94&ExamID=92
*   结果:AC
*   来源:庞果网
*   总结:
**********************************/
#include<iostream>
#include<stdio.h>
#include<string>
using namespace std; 

int run(const int *a,int n){
    int i,j,count=0;
    int *num = new int[n];  
    num = (int*)a;
    //每一次选一个最小的和待选序列交换
    for(i = 0;i < n;i++){
        //选择一个最小的
        int min = i;
        for(j = i+1;j < n;j++){
            if(num[min] > num[j]){
                min = j;
            }
        }
        //最小值和待选序列第一个值交换
        if(num[min] != num[i]){
            int temp;
            temp = num[min];
            num[min] = num[i];
            num[i] = temp;
            count++;
        }
    }
    return count;
}
//start 提示:自动阅卷起始唯一标识,请勿删除或增加。
int main()
{   
    int n = 3;
    int num[4] = {3,2,1}; 
    printf("%d\n",run(num,n));
    return 0;
} 
//end //提示:自动阅卷结束唯一标识,请勿删除或增加。          


分享到:
评论

相关推荐

    数组排序数组排序数组排序数组排序数组排序

    分类标签:选择数组排序,冒泡排序,插入排序,冒泡排序分类标签:选择数组排序,冒泡排序,插入排序,冒泡排序分类标签:选择数组排序,冒泡排序,插入排序,冒泡排序分类标签:选择数组排序,冒泡排序,插入排序,...

    matlab数组排序matlab数组排序

    matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序matlab数组排序...

    易语言自定义数据类型数组排序

    易语言自定义数据类型数组排序源码,自定义数据类型数组排序,更新超级列表框,取随机品名,根据产地排序,根据类别排序,根据售价排序

    C#实现对二维数组排序的方法

    主要介绍了C#实现对二维数组排序的方法,实例分析了C#数组遍历与排序的相关技巧,需要的朋友可以参考下

    java数组排序

    java数组排序的思想,过程和代码实现。多种数组排序的方法,主要有冒泡排序,堆排序,插入排序, 归并操作(merge), 归并操作(merge),选择排序,希尔排序。

    数组排序【庞果网、英雄会】

    以下是题目详情: 给定一个包含1-n的数列,我们通过交换任意两个元素给数列重新排序。求最少需要多少次交换,能把数组排成按1-n递增的顺序,其中,数组长度不超过100。 例如: 原数组是3,2,1, 我们只需要交换1和3...

    VB.NET二维数组快速排序(更新)

    VB.NET二维数组快速排序(更新) 'OldArrays(),为排序二维数组;NewArrays(),为存放结果数组,SortColumnsOrOrders(),传递排序参数数组,偶数个为排序列号,奇数为升降序,0为升序,1为降序;FieldRow,是否有字段行...

    VB多维数组排序源码

    VB多维数组排序源码

    数组应用——一维数组排序

    数组应用——一维数组排序; 定义一组无序的整型数列,共10个数值,经过一定的处理,使该数组由大到小排列,并输出到屏幕上。具体要求如下: 定义int型数组arrayorder并赋初值为0,长度为10,以承载该数列; 使用...

    任意数组排序

    任意数组排序 很经典经典 学习交流

    iOS模型数组排序

    模型数组排序,sortedArrayUsingComparator

    VB二维数组排序源码

    VB二维数组排序源码

    易语言数组排序算法集合

    易语言数组排序算法集合源码,数组排序算法集合,排序程序,冒泡排序,改冒泡法,双向泡排序,双响泡排序,直接插入排序,地精排序,地精排序2,地精排序3,二分排序,选择排序,梳子排序,希尔排序,快速排序

    Labview二维数组排序

    不要看分数高,这个程序绝对可以对得起大家的分数。这个楼主的研究哈!反正下了评价后分数可以返还的................

    二维数组排序

    // 二维数组冒泡排序 public static void main(String[] args) { int i=0, j=0, temp = 0; int[][] nums1 = { { 34, 1, 22, 5 }, { 28, 98, 15, 32 }, { 33, -5, 17, 41 } }; int rows = nums1.length; //二维...

    易语言利用数组进行数值排序

    易语言利用数组进行数值排序,简单粗暴

    二维数组排序.vi二维数组排序.vi

    二维数组排序.vi

    数组排序(难点,重点)

    数组排序数组排序数组排序数组排序数组排序数组排序数组排序

    排序函数(数字或字符串数组排序)

    为普通数组和对象数组排序,对象数组排序时,可指定排序所依据的对象属性,汉字将以汉语拼音为序。

    易语言源码易语言自定义数据类型数组排序.rar

    易语言源码易语言自定义数据类型数组排序.rar 易语言源码易语言自定义数据类型数组排序.rar 易语言源码易语言自定义数据类型数组排序.rar 易语言源码易语言自定义数据类型数组排序.rar 易语言源码易语言自定义...

Global site tag (gtag.js) - Google Analytics