zoukankan      html  css  js  c++  java
  • 奇怪的排序201308051735.txt

    奇怪的排序
    时间限制:1000 ms  |  内存限制:65535 KB
    难度:1
    描述
    最近,Dr. Kong 新设计一个机器人Bill.这台机器人很聪明,会做许多事情。惟独对自然数的理解与人类不一样,它是从右往左读数.比如,它看到123时,会理解成321.让它比较23与15哪一个大,它说15大。原因是它的大脑会以为是32与51在进行比较.再比如让它比较29与30,它说29大.

    给定Bill两个自然数A和B,让它将 [A,B] 区间中的所有数按从小到大排序出来。你会认为它如何排序?

    输入
    第一行: N表示有多少组测试数据. (2<=N<=5 )
    接下来有N行,每一行有两个正整数A B表示待排序元素的区间范围. (1<=A<=B<=200000 B-A<=50)

    输出
    对于每一行测试数据,输出一行,为所有排好序的元素,元素之间有一个空格.
    样例输入
    2
    8 15
    22 39样例输出
    10 8 9 11 12 13 14 15
    30 31 22 32 23 33 24 34 25 35 26 36 27 37 28 38 29 39

     法一:

    #include <stdio.h>
    //#include <stdlib.h>
    //int cmp(const void *a,const void *b)
    //{
     //return(*(int*)a-*(int*)b);
       
    //}
    int main()
    {
     int a[55],b[55],i,m,n,j,t,l,N,k;
     scanf("%d",&N);
     while(N--)
     {
      scanf("%d%d",&m,&n);
      for(i=0;i<n-m+1;i++)
         {
          a[i]=m+i;
          k=m+i;
          l=0;
             while(k>0)
            {
          l=l*10+k%10;
          k=k/10;
            }
                 b[i]=l;
                //printf("%d ",b[i]);
         }
         //qsort(b,n-m+1,sizeof(a[0]),cmp);
         for(j=1;j<=n-m;j++)
         for(i=0;i<=n-m-j;i++)
         if(b[i]>b[i+1])
         {t=b[i];b[i]=b[i+1];b[i+1]=t;
          t=a[i];a[i]=a[i+1];a[i+1]=t;}
         for(i=0;i<=n-m;i++)
         printf("%d ",a[i]);
         printf(" ");
     }
     return 0;
    }

    法二:

    #include <stdio.h>
    #include <stdlib.h>
    //typedef struct IN
    struct IN
    {
     int a;//原数
     int b;//逆序后的数
    }s[60];
    //IN s[60];
    /*
    int nixu(int n,int i)
    {
     int m=0;
     s[i].a=n;
     while(n>0)
     {
      m=m*10+n%10;
      n/=10;
     }
     s[i].b=m;
     return 0;
    }
    */
    /*
    int cmp(const void *a,const void *b)
    {
     struct IN *c = (IN *)a;
     struct IN *d = (IN *)b;
     return c->b - d->b;
    }
    */
    int cmp( const void *a ,const void *b) 

        return (*(IN *)a).b > (*(IN *)b).b ? 1 : -1; 

    int main()
    {
     int N;
        scanf("%d",&N);
      while(N--)
      {
       int i,j,m,n,a,b;
       scanf("%d %d",&m,&n);
       for(j=0,i=m;i<=n;i++)
       {
        a=i;b=0;
                    s[j].a=a;
                 while(a>0)
                 {
                  b=b*10+a%10;
                  a/=10;
                 }
                 s[j].b=b;
                 j++;
       }
       /*for(j=0,i=m;i<=n;i++)
       {
                    nixu(i,j);
                    j++;
                }*/
       qsort(s,n-m+1,sizeof(s[0]),cmp);
       for(i=0;i<n-m+1;i++)
       {
        if(i<n-m)
        printf("%d ",s[i].a);
        else
        printf("%d ",s[i].a);
       }
       /*for(i=0;i<n-m+1;i++)
       {
        if(i<n-m)
        printf("%d ",s[i].b);
        else
        printf("%d ",s[i].b);
       }*/
      }
     return 0;
    }
        
       
       

  • 相关阅读:
    企业网站常用中英文对照表
    AttachJSFunction(一个button同时挂两个onclick事件)
    Js 整理
    宝玉的CSS
    网页中一些比较隐蔽的用法 作者:wbc
    flex中flexgrow作用
    flex实现换行内容上下贴边效果
    flex中自动换行设置,以及上下间距的设置?
    flex中aligncontent和aliginitems区别?
    正则表达式语法及实例整理[转]
  • 原文地址:https://www.cnblogs.com/xiaziteng/p/qiguai.html
Copyright © 2011-2022 走看看