题解 | #坐标移动#

坐标移动

http://www.nowcoder.com/practice/119bcca3befb405fbe58abe9c532eb29

绑架算力了属于是

  • 先将数据分组,放在二维的vector中。
  • 分别处理每一行,按特征剔除不符合的数据。
  • 用到了数据覆盖思想。此法也可用于提取不重复数据(去重)。
  • 总之是笨比方法暴力破解。
  • 啊,我要欣赏一下其他大佬的方法。
#include<string.h>


//AS赋负值,DW赋正值。
//检测ASDW后的数字,与上一个结果做运算,第一个从零开始
//以分号做标志
//不能出现除数字和ASDW以外的字符

char input[10000],n[1000],m[1000],asb[1000][1000]={0};
int len,i=0,j=0,k=0,flag=0,p=0,x = 0,y = 0,dir,dist=0,distance[1000];
char A,S,D,W;
int rank[1000]={-1};
int dis_fen,dis_fen_2,dis_fen_3,dis_fen_4;
char char_list[10]={'0','1','2','3','4','5','6','7','8','9'};
int digital_list[10]={0,1,2,3,4,5,6,7,8,9},d[100];

int main()
{
    while(scanf("%s\n",input) != EOF)
    {
        len = strlen(input);//获取字符串长度
               
        
      
        for(i = 0; i <len ;i++)//获取分号位置
        {
        if(input[i] ==';')
            {
         
            rank[j+1]=i;
            j++;
        }
           }  
          int point=j;
        
        
        
        
        
        
        //二维数组,f分号分隔放在不同行
        //3<坐标相减<4的放入   套:第一个是字母的放入 
        //if坐标=3 看第二位是否是数字
        //else if坐标=4 第二第三位是否是数字
     //  
        
       
        for(i=0;i<point;i++)//分组
        {
            
            for(k = flag,j=0;((input[k] != ';')&&(input[k] != '\n'));k++)
            {
                asb[i][j]=input[k];
                j++;
            }
            
            j=0;
            k++;
            flag=k;
        }
      
         for(i= 0;i<point;i++)//计算每行的长度
    {
         
        distance[i] = rank[i+1]-rank[i]; 
      
    }

       for(i=0;i<point;i++)//长度不符合的剔除
       {
          
           if((distance[i]<3)||(distance[i]>4))
           {
               for(j=i;j<point;j++)
           {
               for(k=0;k<distance[j+1];k++)
               {
                  
                       asb[j][k]=asb[j+1][k];                              
                  
               }  
               distance[j]=distance[j+1];
           
           }
              i--; 
             point--;
       }
       }  
        
        
        
        
         for(i=0;i<point;i++)//首位不符合的剔除
       {
          
           if((asb[i][0] !='A')&&(asb[i][0] !='S')&&(asb[i][0] !='D')&&(asb[i][0] !='W'))
           {
               for(j=i;j<point;j++)
           {
               for(k=0;k<distance[j+1];k++)
               {
                  
                       asb[j][k]=asb[j+1][k];                              
                  
               }  
               distance[j]=distance[j+1];
           
           }
              i--; 
             point--;
       }
       }  
        
        
     for(i=0;i<point;i++)  
     {
         if((asb[i][1]<'0')||(asb[i][1]>'9'))//剔除第二位不是数字的
        
         {
            
            for(j=i;j<point;j++)
           {
               for(k=0;k<distance[j+1];k++)
               {
                  
                       asb[j][k]=asb[j+1][k];                              
                  
               }  
               distance[j]=distance[j+1];
           
           }
              i--; 
             point--;
       } 
             
             
             
             
         
         else
        {   
       
         if(distance[i]==4)
         {
           
             
            if((asb[i][2]<'0')||(asb[i][2]>'9'))//剔除第三位不是数字的
        
         {
            
            for(j=i;j<point;j++)
           {
               for(k=0;k<distance[j+1];k++)
               {
                  
                       asb[j][k]=asb[j+1][k];                              
                  
               }  
               distance[j]=distance[j+1];
           
           }
              i--; 
             point--;
       }   
             
             
             
             
         }
         
         }
         
     }
        
        
        
        
      
    
        
      
        
        
        
        //仿照单片机进行表查找
        
        
        for(i=0;i<point;i++)
        {
          
            
            
            if(distance[i]==3)//个位数距离
            {
                
                for(j=0;j<10;j++)
                {
                    if(asb[i][1]==char_list[j])
                    {
                        
                        d[i]=digital_list[j];
                    }
                    
                    
                }
            }
              
                   
            
            
            else//十位数距离
            {
                for(j=0;j<10;j++)
                {
                    if(asb[i][1]==char_list[j])
                    {
                        
                        d[i]=digital_list[j]*10;
                    }
                    
                    
                }
                
                
                 for(j=0;j<10;j++)
                {
                    if(asb[i][2]==char_list[j])
                    {
                        
                        d[i]=d[i]+digital_list[j];
                    }
                    
                    
                }
                                
            }
            
            
           
            
            
          }
            
            
           
        for(i=0;i<point;i++)
            {
            
            switch(asb[i][0])
              {  
                case 'A': 
                { 
                    x =x-d[i];
                    break;
                }
                case 'S': 
                {
                    y =y-d[i];
                    break;
                }
                case 'D': 
                {
                      x = x+d[i];
                    break; 
                }
                case 'W':
                {
                    y = y+d[i];
                    break;
                }
            }
            }
                 
              
        
        
         printf("%d,%d",x,y);  
        



     
        
        
    }

}
全部评论

相关推荐

04-16 10:27
已编辑
美团_Saas_后端开发
今天周一休息,突发奇想写一篇阶段总结。如题,我已经去了一个和Java彻底毫无关联的行业。曾经我以为自己能在计算机行业发光发热,拿到美团offer那会感觉自己天都亮了。没想到刚入行一年多就当了逃兵。从最开始的热爱到现在一看到代码就厌恶,不知道自己经历了什么。所以我去干什么了?答案是:在成都当了租房销售。上班那会压力大了就念叨着去干租房中介,但是一直下不去这个决心,想着自己学了四年多的计算机知识,终究还是不甘心。终于在某一天准备八股文的时候,看着无数篇和工作内容关系不大的理论知识,那一刻下定决心,决定尝试一下销售行业,也算是给自己一个交代。后面阴差阳错的投了成都自如去当租房管家,没想到面试很顺利,在当天一百多个面试的人里面,我成为了为数不多通过的几个幸运儿之一。目前已经培训通过,正式入职,也开了单,有压力但是每天过得很开心,真心喜欢那种和人交流的感觉,哪怕是最后没有选择找我租房。说这些也是想告诉那些大三,大四正在找Java实习而焦虑的同学:你们现在还年轻,选择很多,容错率也很高,可以尽情去尝试自己喜欢的行业和工作。不用因为某一次的面试没通过或者简历石沉大海而焦虑,更不用因为身边人都在挤编程的独木桥就强迫自己跟风。也算是自己的碎碎念吧,也希望自己能在新的领域取得一点小成就。也祝牛油工作顺利!
沉淀小子:干啥都不丢人啊,生存是必须要的,销售很考验一个人综合素质能力的,好的销售人脉和资源可不比写字楼的白领差啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务