milk


私信TA

用户名:Soymilk

访问量:6875

签 名:

算法好难啊

等  级
排  名 85
经  验 9359
参赛次数 5
文章发表 10
年  龄 0
在职情况 学生
学  校 interesting
专  业

  自我简介:

解题思路:
数字拆分
注意事项:
0也要输出
参考代码:

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
typedef struct {
 int a,b,c;
}per;//拆分三部分
int comp(const void *m,const void *n){//qsort排序
 if(((per*)n)->b==((per*)m)->b){
  if(((per*)n)->a==((per*)m)->a){
   return ((per*)n)->c-((per*)m)->c;
  }
  return ((per*)n)->a-((per*)m)->a;
 }
 return ((per*)n)->b-((per*)m)->b;
}
int main(){
 int n,i,j,ans;
 scanf("%d",&n);
 per p[n];
 for(i=0;i<n;i++){
  scanf("%6d%8d%4d",&p[i].a,&p[i].b,&p[i].c);
 } 
 qsort(p,n,sizeof(per),comp);
 for(i=0;i<n;i++){
  for(j=6;j>0;j--){//为了保证0也输出,so..
   ans=p[i].a%(int)pow(10,j)/pow(10,j-1);
   printf("%d",ans);
  }
  for(j=8;j>0;j--){
   ans=p[i].b%(int)(pow(10,j))/pow(10,j-1);
   printf("%d",ans);
  }
  for(j=4;j>0;j--){
   ans=p[i].c%(int)(pow(10,j))/pow(10,j-1);
   printf("%d",ans);
  }
  printf("\n");
 }
 return 0;
}


 

0.0分

5 人评分

  评论区

  • «
  • »