数列转换

时间限制:3000 ms  |  内存限制:65535 KB
难度:3
 
描述

有一个数列a1,a2,a3...an,每次可以从中任意选三个相邻的数ai-1 ,a, ai+1 ,进行如下操作(此操作称为“对ai进行操作”)

(ai-1,ai,ai+1)->(ai-1+ai,-ai,ai+ai+1)

给定初始和目标序列,是否能通过以上操作,将初始序列转换成为目标序列?例如,初始序列(1 6 9 4 2 0)目标序列(7 -6 19 2 -6 6)可经过如下操作:

 (1 6 9 4 2 0)->( 1 6 13 -4 6 0)->(1 6 13 2 -6 6)->(7 -6 19 2 -6 6)

请你判断给定的初始状态和目标状态,输出Yes(能够转换)或No(不能转换)

 
输入
第一行是一个正整数N,表示测试数据的组数。(N<=100)
每组测试数据的第一行是一个整数M(3<=M<=1000),表示该组测试数据的起始状态与结束状态都有M个数。
每组测试数据的第二行是M个整数Ai(-1000<=Ai<=1000),表示起始状态。
每组测试数据的第三行是M个整数Bi(-1000<=Bi<=1000),表示终止状态。
输出
如果能够转换,输出Yes
如果不能转换,输出No
样例输入
2
3
1 2 3
1 3 2
6
1 6 9 4 2 0
7 -6 19 2 -6 6
样例输出
No
Yes
来源
《世界大学生程序设计竞赛高级教程·第一册》
 1 //本题算法请参照上一篇博文http://www.cnblogs.com/dongsheng/archive/2013/03/04/2943099.html
  //主要是守恒法的应用
2 #include <iostream> 3 #include <algorithm> 4 #include <string> 5 using namespace std; 6 7 int sum1[1001], sum2[1001]; 8 9 int main() 10 { 11 int T, n, i; 12 cin >> T; 13 while(T--) 14 { 15 cin >> n; 16 for(i = 1; i <= n; ++i) 17 { 18 cin >> sum1[i]; 19 sum1[i] += sum1[i-1]; 20 } 21 for(i = 1; i <= n; ++i) 22 { 23 cin >> sum2[i]; 24 sum2[i] += sum2[i-1]; 25 } 26 sort(sum1 + 1, sum1 + n +1); 27 sort(sum2 + 1, sum2 + n + 1); 28 for(i = 1; i <= n; ++i) 29 { 30 if(sum1[i] != sum2[i]) 31 break; 32 } 33 if(i == n + 1) 34 //puts("Yes"); 35 cout << "Yes" << endl; 36 else 37 //puts("No"); 38 cout << "No" << endl; 39 } 40 return 0; 41 }

 

posted on 2013-03-04 18:10  可笑痴狂  阅读(1362)  评论(0编辑  收藏  举报