杭電acm 1015題

立刻要找工做了,鍛鍊下本身的寫程序能力,很少說,上代碼ios

 1 /********************杭電acm 1015 已AC
 2                      在這個程序裏,使用窮舉法來實現,可是輸出順序須要安裝字典的最大
 3                      來輸出
 4                      1,在升序排序時,能夠直接使用sort這個函數,也能夠本身寫..
 5                          在本身寫的程序裏面要注意下標的越界問題
 6       ***********************************/
 7 
 8 #include "iostream"
 9 
10 
11 using namespace std;
12 
13 #define Max 20
14 int main(void)
15 {
16     int target;
17     int len;
18     int temp=0;
19     int mark=0;
20     char letters[Max];
21     int flag[5]={0};
22     int nu[Max];
23     cin>>target;
24     while(target)
25     {
26         for(int f=0;f<5;f++)
27             flag[f]=0;
28         mark=0;
29         cin>>letters;
30         len=strlen(letters);
31         if((target==0)&&(!strcmp(letters,"END")))
32             break;
33         for(int i=0;i<len;i++)
34             nu[i]=letters[i]-'A'+1;
35         //將全部的都排好順序,這樣才能保證枚舉出來的一組是按字典最大的一組
36         for(i=0;i<len;i++)
37         {
38             for(int t=1;t<len-i;t++)//注意這裏排序的時候t=1,否則可能會下標越界
39              {if(nu[t-1]>nu[t])
40                 {
41                     int tt=nu[t];
42                     nu[t]=nu[t-1];
43                     nu[t-1]=tt;
44                     char ss=letters[t];
45                     letters[t]=letters[t-1];
46                     letters[t-1]=ss;
47                 }
48              }
49         }
50         //for(int t=0;t<len;t++)
51         //    cout<<nu[t]<<" ";
52         //cout<<endl;
53 
54         for(i=0;i<len;i++)
55         {
56             for(int j=0;j<len;j++)
57             {
58                 for(int m=0;m<len;m++)
59                 {
60                     for(int n=0;n<len;n++)
61                     {
62                         for(int s=0;s<len;s++)
63                         {
64                             if(i!=j&&i!=m&&i!=n&&i!=s&&j!=m&&j!=n&&j!=s&&m!=n&&m!=s&&n!=s)
65                             {temp=nu[i]-nu[j]*nu[j]+nu[m]*nu[m]*nu[m]-nu[n]*nu[n]*nu[n]*nu[n]+nu[s]*nu[s]*nu[s]*nu[s]*nu[s];
66                                 if(target==temp)
67                                 {                            
68                             
69                                     
70                                     flag[0]=i;flag[1]=j;flag[2]=m;flag[3]=n;flag[4]=s;
71                                     mark=1;
72                                     
73                             //    goto Out;
74                                 }
75                             }
76                             
77                         }
78                     }
79                 }
80             }
81         }
82             //Out:
83             if(mark==0)
84                 cout<<"no solution"<<endl;
85             else
86                 cout<<letters[flag[0]]<<letters[flag[1]]<<letters[flag[2]]<<letters[flag[3]]<<letters[flag[4]]<<endl;
87                 cin>>target;
88             
89     }
90     
91     return 0;
92 
93 }

這個題目直接使用暴力窮舉法能夠解決,估計是系統的數據弱了.....函數

相關文章
相關標籤/搜索