逻辑幻象


私信TA

用户名:miragelogic

访问量:27283

签 名:

稳中带皮,还有点方

等  级
排  名 264
经  验 5868
参赛次数 0
文章发表 80
年  龄 0
在职情况 学生
学  校 浙江海洋大学
专  业 机械电子工程

  自我简介:

解题思路:

括号没算进去

大致看一下思路把

注意事项:

参考代码:

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int jia(int a,int b){
 return a+b;
}
int jian(int a,int b){
 return a-b;
}
int cheng(int a,int b){
 return a*b;
}
int chu(int a,int b){
 if(b==0){
  return ;
 }
 return a/b;
}
int c[24][4];
int a[4],ls[4];
int q=0;
int cs[4]={0,1,2,3};
void jihe(int m){
 if(m==4){
  int p;
  for(p=0;p<4;p++){
   c[q][p]=a[ls[p]];
  }
  q++;
  return ;
 }
 int i,j;
 for(i=0;i<4;i++){
  int tap=0;
  for(j=0;j<m;j++){
   if(ls[j]==cs[i]){
    tap=1;
   }
  }
  if(tap==0){
   ls[m]=cs[i];
   jihe(m+1);
  }
 }
}
int main(){
 char b[12];
 gets(b);
 int i=0,j=0,k;
 k=strlen(b);
 while(i<=k){
  if(b[i]>='2' && b[i]<='9'){
   a[j++]=b[i]-'0';
  }
  else if(b[i]=='A'){
   a[j++]=1;
  }
  else if(b[i]=='J'){
   a[j++]=11;
  }
  else if(b[i]=='Q'){
   a[j++]=12;
  }
  else if(b[i]=='K'){
   a[j++]=13;
  }
  else if(b[i]=='1' && b[i+1]=='0'){
   a[j++]=10;
   i++;
  }
  i++;
 }
 memset(ls,0,sizeof(ls));
 int (*ys[4])(int,int)={jia,jian,cheng,chu};//函数指针指向+-*/几个函数
 int m=0;
 jihe(m);
    int x1,x2,x3,sum,bj=0;
    for(i=0;i<24;i++){
     for(x1=0;x1<4;x1++){
      for(x2=0;x2<4;x2++){
       for(x3=0;x3<4;x3++){
        sum=ys[x1](c[i][0],ys[x2](c[i][1],ys[x3](c[i][2],c[i][3])));
        if(sum==24){
         bj=1;
         break;
        }
       }
      }
     }
 }
 if(bj==0){
  printf("N\n");
 }
 else{
  printf("Y");
 }
 return 0;
}


 

0.0分

15 人评分

  评论区

  • «
  • »