poj 2466 Pairsumonious Numbers

poj 2466 Pairsumonious Numbers,第1张

poj 2466 Pairsumonious Numbers
#include<iostream>#include<cstdio>#include<cstring>#include<cmath>#include<algorithm>using namespace std;int a[50];int x[15];int flag[50];bool cmp(int x, int y){    return x < y;}int main(){    int n;    while(scanf("%d", &n) != EOF){        int m = n * (n - 1) / 2;        for(int i = 1; i <= m; i++) scanf("%d", &a[i]);        sort(a + 1, a + 1 + m, cmp);        bool corr;        for(int i = 3; i <= m; i++){ memset(flag, 0, sizeof(flag)); x[1] = (a[1] + a[2] - a[i]) / 2; x[2] = (a[i] + a[1] - a[2]) / 2; x[3] = (a[2] + a[i] - a[1]) / 2; if((a[1] + a[2] - a[i]) % 2 != 0 || (a[i] + a[1] - a[2]) % 2 != 0 || (a[2] + a[i] - a[1]) % 2 != 0){     corr = false;     continue; } flag[1] = flag[2] = flag[i] = 1; int k = 0; while(4 + k <= n){     for(int j = 1; j <= m; j++){         if(flag[j] == 0){  flag[j] = 1;  x[4 + k] = a[j] - x[1];  break;         }     }     for(int j = 1; j < 4 + k; j++){         for(int l = 1; l <= m; l++){  if((a[l] == x[4 + k] + x[j]) && flag[l]==0){      flag[l] = 1;      break;  }         }     }     k++; } corr = true; for(int j = 1; j <= m; j++){     if(flag[j] == 0){         corr = false;         break;     } } if(corr == true)     break;        }        if(corr == false) printf("Impossiblen");        else{ for(int i = 1; i <= n; i++)     printf("%d ",x[i]); printf("n");        }    }    return 0;}

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/4907562.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-11-12
下一篇2022-11-12

发表评论

登录后才能评论

评论列表(0条)

    保存