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

bingo

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  0 隨筆 :: 4 文章 :: 1 評論 :: 0 Trackbacks

 

  1//金幣陣列問題,待改進。。。
  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個數相等的行往下沉 
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個數相等的行之上的所有列 
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個數相等的行 
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            //找到和目標第一列的最優匹配 
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 閱讀(569) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产一区二区福利| 9色porny自拍视频一区二区| 亚洲三级性片| 亚洲成色www8888| 亚洲高清久久网| 日韩一区二区福利| 午夜精品在线视频| 麻豆91精品| 亚洲精品免费网站| 亚洲国产精品成人va在线观看| 黄色在线一区| 亚洲人体影院| 亚洲欧美成人网| 久久久久久久一区| 亚洲国产成人精品久久久国产成人一区| 亚洲黄色天堂| 午夜伦欧美伦电影理论片| 久久久亚洲国产天美传媒修理工| 米奇777超碰欧美日韩亚洲| 欧美日韩一视频区二区| 国产精品一区二区你懂得| 亚洲承认在线| 午夜日本精品| 亚洲电影免费观看高清完整版在线 | 国外成人在线视频网站| 亚洲欧洲精品一区二区三区 | 国产综合av| 日韩西西人体444www| 久久国产手机看片| 日韩午夜激情| 久久影视精品| 国产午夜精品视频| 亚洲一区二区四区| 欧美激情在线播放| 欧美综合第一页| 国产精品久久久久9999高清| 亚洲国产三级| 蜜臀av在线播放一区二区三区| 一区二区三区国产盗摄| 欧美 日韩 国产精品免费观看| 国产免费观看久久黄| 亚洲无毛电影| 日韩视频在线播放| 欧美激情亚洲自拍| 亚洲国产精品嫩草影院| 看欧美日韩国产| 欧美在线视频观看免费网站| 国产精品视频一| 性欧美超级视频| 亚洲一区观看| 国产乱码精品一区二区三区不卡| 亚洲在线免费观看| 999在线观看精品免费不卡网站| 嫩模写真一区二区三区三州| 亚洲高清不卡在线| 欧美激情精品久久久六区热门 | 久久都是精品| 亚洲男人的天堂在线aⅴ视频| 国产精品白丝黑袜喷水久久久| 欧美日韩高清一区| 99视频精品在线| 亚洲区欧美区| 欧美精品一区二区久久婷婷| 亚洲欧洲日本mm| 亚洲激情视频在线播放| 欧美精品一区二区蜜臀亚洲 | av成人免费在线观看| 亚洲电影免费在线观看| 欧美韩国日本一区| 一区二区精品国产| 99在线热播精品免费99热| 欧美特黄一区| 欧美在线视频a| 久久裸体视频| 日韩亚洲精品在线| 一区二区三区欧美激情| 国产麻豆9l精品三级站| 久久网站免费| 欧美韩国日本综合| 亚洲欧美国产精品桃花| 欧美在线视频观看免费网站| 亚洲欧洲一区二区在线播放| 亚洲精品久久久久久久久久久久久| 欧美日韩国产美| 久久精品91| 欧美大片免费| 香蕉久久精品日日躁夜夜躁| 久久精品九九| 99这里只有精品| 欧美在线91| 亚洲视频久久| 久久精品视频在线| 在线一区亚洲| 久久久综合免费视频| 亚洲网站在线观看| 久久亚洲色图| 香蕉久久久久久久av网站| 毛片基地黄久久久久久天堂| 亚洲性色视频| 免费视频久久| 久久久久久久精| 欧美日本国产在线| 免费高清在线视频一区·| 欧美三级网址| 亚洲高清一区二| 国产综合色在线视频区| 一本久久综合亚洲鲁鲁五月天| 一区二区亚洲| 午夜久久久久久| 一区二区三区www| 欧美成人蜜桃| 男女激情久久| 国模 一区 二区 三区| 中文日韩电影网站| 999亚洲国产精| 久久久久久久网站| 性欧美超级视频| 欧美体内she精视频在线观看| 欧美激情麻豆| 亚洲第一在线综合在线| 久久国产精品99国产| 午夜精品视频在线观看| 欧美日韩视频| 亚洲尤物精选| 欧美日韩免费在线观看| 亚洲经典在线看| 亚洲精品国产无天堂网2021| 久久久噜噜噜久久中文字免| 久久精品国产一区二区电影| 国产精品久久久久久模特| 一区二区高清在线观看| 一区二区成人精品| 欧美日韩精品综合| 日韩亚洲欧美精品| 一区二区三区 在线观看视频| 欧美黄色一级视频| 亚洲欧洲在线一区| 在线午夜精品| 国产精品视频导航| 亚洲欧美日韩一区在线| 久久福利精品| 在线观看国产精品网站| 老司机精品导航| 亚洲高清视频一区| 一区二区三区四区五区精品| 国产精品va| 欧美亚洲日本网站| 欧美福利专区| 在线亚洲国产精品网站| 国产精品久久久久9999高清 | 午夜精品免费| 久久中文欧美| 亚洲美女视频在线观看| 欧美午夜精品久久久久久孕妇 | 日韩午夜免费视频| 亚洲欧美国产精品桃花| 国产字幕视频一区二区| 欧美夫妇交换俱乐部在线观看| 91久久国产综合久久| 亚洲一区二区综合| 激情婷婷欧美| 欧美日本精品| 欧美一区日本一区韩国一区| 欧美二区不卡| 亚洲午夜日本在线观看| 狠狠色丁香婷婷综合影院| 欧美高清自拍一区| 亚洲欧美网站| 亚洲欧洲日韩综合二区| 欧美一区2区三区4区公司二百| 红桃视频亚洲| 国产精品二区二区三区| 久久精精品视频| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲在线免费| 亚洲精品一区二区三区99| 国产欧美日韩一区| 欧美另类在线观看| 久久精品成人欧美大片古装| 亚洲另类视频| 免费视频一区| 久久国产一二区| 亚洲女人av| 99国产精品自拍| 亚洲第一精品久久忘忧草社区| 国产精品二区二区三区| 欧美激情女人20p| 久久成人精品电影| 亚洲一区三区电影在线观看| 亚洲黄色视屏| 欧美成人伊人久久综合网| 久久福利电影| 欧美在线首页| 国产亚洲精品一区二555| 欧美黄色影院| 蜜桃久久精品乱码一区二区| 久久精品动漫| 性色av一区二区三区| 亚洲图片欧洲图片av| 夜夜爽www精品|