青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

bingo

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  0 隨筆 :: 4 文章 :: 1 評(píng)論 :: 0 Trackbacks

 

  1//金幣陣列問題,待改進(jìn)。。。
  2
  3#include <stdio.h> 
  4#include <memory.h> 
  5
  6int ma[100][101], mb[100][101], mc[100][101]; 
  7int steps, tempsteps; 
  8int m, n; 
  9FILE *input, *output; 
 10
 11int input_matrix(int [][]); 
 12int row_overturn(int [][], int); 
 13int row_exchange(int [][], intint); 
 14int row_match(int [][], int [][], int); 
 15int col_match(intintintint); 
 16int col_exchange(intint); 
 17int evaluate(intint); 
 18int matrix_copy(int [][], int [][], intint); 
 19
 20int row_match(int mx[][101], int my[][101], int i) 
 21
 22    int j, count = 0
 23    for (j = 1; j <= n; ++j) 
 24        if (mx[i][j] != my[i][j]) 
 25            ++count; 
 26    if (count == n) 
 27        return 1
 28    else if(!count) 
 29        return 0
 30    else 
 31        return -1
 32}
 
 33
 34int input_matrix(int mx[][101]) 
 35
 36    int i, j, count1; 
 37    int tag = 0
 38    for (i = 0; i < m; ++i) 
 39    
 40        count1 = 0
 41        for (j = 1; j <= n; ++j) 
 42        
 43            fscanf(input, "%d"&mx[i][j]); 
 44            if (mx[i][j]) 
 45                ++count1; 
 46        }
 
 47
 48        if (count1 * 2 != n) 
 49        
 50            mx[i][0= count1; 
 51            if (i != tag) 
 52                row_exchange(mx, i, tag); 
 53            ++tag; 
 54        }
 
 55        else 
 56            mx[i][0= -1
 57    }
 
 58
 59    return tag; 
 60}
 
 61
 62int row_overturn(int mx[][101], int thisrow) 
 63
 64    int j; 
 65
 66    for (j = 1; j <= n; j++
 67        mx[thisrow][j] = mx[thisrow][j] ^ 1
 68    if (mx[thisrow][0>= 0
 69        mx[thisrow][0= n - mx[thisrow][0]; 
 70
 71    ++steps; 
 72
 73    return 0
 74}
 
 75
 76int row_exchange(int mx[][101], int row1, int row2) 
 77
 78    int j, temp; 
 79    for (j = 0; j <= n; ++j) 
 80    
 81        temp = mx[row1][j]; 
 82        mx[row1][j] = mx[row2][j]; 
 83        mx[row2][j] = temp; 
 84    }
 
 85
 86    return 0
 87}
 
 88
 89int col_match(int x, int y, int fromrow, int torow) 
 90
 91    int i; 
 92    for (i = fromrow; i < torow; ++i) 
 93        if (ma[i][x] != mb[i][y]) 
 94            return 0
 95
 96    return 1
 97}
 
 98
 99int col_exchange(int col1, int col2) 
100
101    int i, temp; 
102    for (i = 0; i < m; ++i) 
103    
104        temp = ma[i][col1]; 
105        ma[i][col1] = ma[i][col2]; 
106        ma[i][col2] = temp; 
107    }
 
108    ++steps; 
109
110    return 0
111}
 
112
113int matrix_copy(int mx[][101], int my[][101], int rowbound, int colbound) 
114
115    int i, j; 
116    for (i = 0; i < rowbound; ++i) 
117        for (j = 0; j <= colbound; ++j) 
118            mx[i][j] = my[i][j]; 
119
120    return 0
121}
 
122
123int evaluate(int fromrow, int col) 
124
125    int i, degree = 0
126    for (i = fromrow; i < m; ++i) 
127        if (ma[i][col] == mb[i][1]) 
128            ++degree; 
129
130    return degree; 
131}
 
132
133int main() 
134
135    int c, i, j, j1, from, able, tag1, tag2, step, bestcol = 1, temp; 
136    int order[101], count[101]; 
137
138    output = fopen("output.txt""w"); 
139    input = fopen("input.txt""r"); 
140
141    fscanf(input, "%d"&c); 
142
143    for ( ; c; --c) 
144    
145        fscanf(input, "%d %d"&m, &n); 
146        tag1 = input_matrix(ma); 
147        tag2 = input_matrix(mb); 
148
149        if (tag1 != tag2) 
150        
151            fprintf(output, "-1\n"); 
152            continue
153        }
 
154        else 
155        
156            //將 1,0個(gè)數(shù)相等的行往下沉 
157            for (i = 0, able = 1; i < tag1; ++i) 
158            
159                if (ma[i][0== mb[i][0]) 
160                    continue
161                else if (ma[i][0== n - mb[i][0]) 
162                    row_overturn(ma, i); 
163                else 
164                
165                    fprintf(output, "-1\n"); 
166                    able = 0
167                    goto loop1; 
168                }
 
169            }
 
170            loop1: 
171                if (!able) 
172                    continue
173
174            //排列 1,0個(gè)數(shù)相等的行之上的所有列 
175            for (j = 1, from = 1; j <= n; ++j) 
176            
177                for (j1 = from, able = 0; j1 <= n; ++j1) 
178                    if (col_match(j1, j, 0, tag1)) 
179                    
180                        if (j1 != j) 
181                            col_exchange(j1, j); 
182                        ++from; 
183                        able = 1
184                        break
185                    }
 
186
187                if (!able) 
188                
189                    fprintf(output, "-1\n"); 
190                    goto loop2; 
191                }
 
192            }
 
193            loop2: 
194                if (!able) 
195                       continue
196
197            if (tag1 == m) 
198            
199                fprintf(output, "%d\n", steps); 
200                continue
201            }
 
202
203            //處理剩下 0,1個(gè)數(shù)相等的行 
204            for (j = 1; j <= n; ++j) 
205            
206                order[j] = j; 
207                count[j] = evaluate(tag1, j); 
208            }
 
209
210            for (i = 1; i < n; ++i) 
211                for (j = 1; j <= n - i; ++j) 
212                    if (count[j] < count[j + 1]) 
213                    
214                        temp = order[j]; 
215                        order[j] = order[j + 1]; 
216                        order[j + 1= temp; 
217                    }
 
218
219            /* 
220            for (j = 1; j <= n; ++j) 
221                printf("%-2d ", count[order[j]]); 
222
223            printf("\n"); 
224
225            for (j = 1; j <= n; ++j) 
226                printf("%-2d ", order[j]); 
227
228            printf("\n"); 
229            */
 
230
231            for (i = tag1, able = 1, tempsteps = 0; i < m; ++i) 
232            
233                step = row_match(ma, mb, i); 
234                if (step < 0
235                
236                    able = 0
237                    break
238                }
 
239                else if (step) 
240                    tempsteps += step; 
241                else 
242                    ; 
243            }
 
244
245            if (able) 
246            
247                steps += tempsteps; 
248                fprintf(output, "%d\n", steps); 
249                continue
250            }
 
251
252            tempsteps = steps; 
253
254            //找到和目標(biāo)第一列的最優(yōu)匹配 
255            loop3: 
256            steps = tempsteps; 
257            for (j1 = bestcol, j = order[j1], able = 0; j1 <= n; ++j1) 
258                if (col_match(j, 10, tag1)) 
259                
260                    able = 1
261                    matrix_copy(mc, ma, m, n); 
262                     bestcol = j1 + 1
263                    for (i = tag1; i < m; ++i) 
264                        if (ma[i][j] != mb[i][1]) 
265                               row_overturn(ma, i); 
266                    if (j != 1
267                        col_exchange(j, 1); 
268                    break
269                }
 
270
271            if (!able) 
272            
273                fprintf(output, "-1\n"); 
274                continue
275            }
 
276
277               for (j = 2, from = 2; j <= n; ++j) 
278            
279                for (j1 = from, able = 0; j1 <= n; ++j1) 
280                
281                    if (col_match(j1, j, 0, m)) 
282                    
283                        if (j1 != j) 
284                            col_exchange(j, j1); 
285                        able = 1
286                        ++from; 
287                        break
288                    }
 
289                }
 
290                if (!able) 
291                    break
292            }
 
293
294            //找到 
295            if (able) 
296            
297                for (i = 0; i < m; ++i) 
298                
299                    for (j = 0; j <= n; ++j) 
300                        printf("%-2d ", ma[i][j]); 
301                    printf("\n"); 
302                }
 
303                printf("steps: %d\n", steps); 
304                continue
305            }
 
306            else if (!able && bestcol == n - 1
307            
308                fprintf(output, "-1\n"); 
309                continue
310            }
 
311            else 
312            
313                for (i = 0; i < m; ++i) 
314                
315                    for (j = 0; j <= n; ++j) 
316                        printf("%-2d ", mc[i][j]); 
317                    printf("\n"); 
318                }
 
319                matrix_copy(ma, mc, m, n); 
320                goto loop3; 
321            }
 
322        }
 
323        steps = 0
324    }
 
325
326    /* 
327    for (i = 0; i < m; ++i) 
328    { 
329        for (j = 0; j <= n; ++j) 
330            printf("%-2d ", ma[i][j]); 
331        printf("\n"); 
332    } 
333
334    printf("\n"); 
335
336    for (i = 0; i < m; ++i) 
337    { 
338        for (j = 0; j <= n; ++j) 
339            printf("%-2d ", mb[i][j]); 
340        printf("\n"); 
341    } 
342    */
 
343
344    return 0
345}

346
posted on 2008-12-24 15:26 bingo 閱讀(571) 評(píng)論(0)  編輯 收藏 引用

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久av毛片精品| 亚洲欧洲在线观看| 国产精品国产三级欧美二区| 老色批av在线精品| 亚洲综合久久久久| 一色屋精品视频免费看| 欧美日韩国产探花| 美国十次成人| 午夜精品电影| 久久亚洲免费| 欧美在线国产精品| 亚洲另类在线视频| 亚洲国产精品激情在线观看| 国产精品一二| 欧美精品大片| 久久久久久伊人| 亚洲国产精品久久久久秋霞不卡| 亚洲欧美在线磁力| 最近看过的日韩成人| 一区二区三区在线观看欧美| 国产乱码精品1区2区3区| 欧美激情视频在线播放| 蜜桃久久精品乱码一区二区| 欧美影视一区| 亚洲欧美成人网| 亚洲图色在线| 日韩午夜在线播放| 亚洲另类在线视频| 欧美黄色片免费观看| 久久伊人精品天天| 久久久免费精品视频| 亚洲欧美日韩在线一区| 最近中文字幕日韩精品| 怡红院精品视频在线观看极品| 亚洲欧美国内爽妇网| 在线一区观看| 一本色道久久88亚洲综合88| 午夜精品久久久99热福利| 夜色激情一区二区| 欧美裸体一区二区三区| 久久成人18免费网站| 亚洲一区精品视频| 亚洲一区网站| 亚洲综合日韩在线| 欧美**字幕| 欧美激情精品久久久久久久变态| 裸体一区二区三区| 欧美国产精品久久| 欧美国产日本韩| 欧美成人午夜激情视频| 亚洲国产精品一区制服丝袜 | 久久亚洲美女| 欧美专区在线播放| 欧美一区二区三区在| 久久久久久久97| 久久综合色播五月| 欧美日韩国产精品| 国产精品久久777777毛茸茸| 欧美在线一区二区| 久久久精品性| 猛干欧美女孩| 欧美视频在线观看 亚洲欧| 欧美特黄一区| 欧美日韩裸体免费视频| 国产精品一区毛片| 国产亚洲激情在线| 亚洲欧洲一区二区三区| 99国内精品| 日韩亚洲精品视频| 性色av一区二区怡红| 久久久xxx| 亚洲高清影视| 一区二区三区国产在线观看| 亚洲国产精品一区制服丝袜 | 国产一区二区三区高清在线观看 | 亚洲网站在线播放| 午夜精品福利一区二区蜜股av| 久久综合国产精品台湾中文娱乐网| 免费在线观看成人av| 欧美一区二区成人6969| 久热国产精品| 亚洲精品一区在线观看| 久久激情网站| 欧美久久精品午夜青青大伊人| 99re热精品| 久久国产直播| 欧美日韩国产一区精品一区| 国产日韩在线看片| 91久久精品美女| 日韩视频在线一区二区三区| 久久都是精品| 亚洲高清不卡一区| 午夜精品成人在线视频| 欧美大片在线看| 欧美区一区二| 尤物九九久久国产精品的特点| 99精品国产在热久久婷婷| 久久久精品网| 亚洲精华国产欧美| 午夜在线成人av| 欧美精品福利在线| 国产视频观看一区| 在线亚洲成人| 蜜桃精品久久久久久久免费影院| 蜜桃视频一区| 小黄鸭精品aⅴ导航网站入口| 久久综合九色九九| 国产精品一区二区久久| 亚洲精品国产精品久久清纯直播| 日韩视频免费观看高清在线视频| 久久久久久亚洲精品杨幂换脸| 亚洲精品欧美专区| 久久综合九色综合欧美狠狠| 国产精品午夜视频| 99国产精品久久久久久久| 欧美夫妇交换俱乐部在线观看| 一本色道久久综合| 欧美日韩123| 亚洲黄色成人网| 久久久久久午夜| 亚洲午夜激情免费视频| 欧美二区乱c少妇| 亚洲国产mv| 久久久久国产精品麻豆ai换脸| 久久精品人人| 亚洲一区二区三区四区五区午夜 | 欧美日韩国产在线| 亚洲人成毛片在线播放| 久久亚洲一区二区| 亚洲欧美怡红院| 国产精品亚洲人在线观看| 国产精品盗摄一区二区三区| 欧美色大人视频| 亚洲国产精品久久久久婷婷884 | 午夜欧美不卡精品aaaaa| 欧美日韩午夜剧场| 一区二区电影免费观看| 米奇777超碰欧美日韩亚洲| 99精品视频网| 亚洲精品免费看| 另类尿喷潮videofree | 尤物精品在线| 久久久伊人欧美| 欧美在线关看| 欧美日韩在线一区二区| 一区二区三区日韩| 亚洲日本成人| 欧美性猛交一区二区三区精品| 亚洲美女av电影| 午夜亚洲福利在线老司机| 亚洲免费一级电影| 国产精品视频精品视频| 久久疯狂做爰流白浆xx| 午夜精品成人在线视频| 国产日本欧美一区二区| 欧美一区二区三区成人| 亚洲欧美日韩中文视频| 欧美成人午夜剧场免费观看| 国际精品欧美精品| 欧美一区二区三区日韩视频| 久久成人精品视频| 极品尤物一区二区三区| 亚洲高清视频一区| 欧美人牲a欧美精品| 亚洲香蕉在线观看| 中文精品视频| 麻豆成人91精品二区三区| 亚洲精华国产欧美| 亚洲精品久久久久久下一站| 国产精品国码视频| 欧美一级在线视频| 久久久久久欧美| 久久精品亚洲| 国产一区二区三区在线观看免费视频 | 久久久久久久欧美精品| 91久久精品日日躁夜夜躁国产| 免费成人高清视频| 欧美精品在线观看播放| 亚洲小说欧美另类社区| 欧美一级淫片播放口| 亚洲国产欧美久久| 欧美美女喷水视频| 欧美一区二区三区视频| 久久国产一区二区三区| 亚洲精品影院在线观看| 在线视频免费在线观看一区二区| 欧美日韩国产高清视频| 欧美一区二区三区四区高清| 欧美一区二区久久久| 亚洲精品无人区| 一本久道久久综合狠狠爱| 亚洲伦伦在线| 狠狠色丁香婷婷综合影院| 亚洲丰满在线| 国产欧美三级| 亚洲国产成人精品久久| 国产精品区一区| 欧美ed2k| 欧美性视频网站| 欧美大片在线观看一区|