zoukankan      html  css  js  c++  java
  • NYOJ109 数列转换

    数列转换

    时间限制: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 }
    功不成,身已退
  • 相关阅读:
    vue绑定值与字符串拼接两种写法
    cmd 总是很卡,执行一条指令就卡死
    生产工具vscode
    js 关于 array 的相关操作––
    webAssembly
    github上fork别人的分支到目录下  
    68.Promise和setTimeout的区别
    67、Promise 构造函数是同步执行还是异步执行,那么 then 方法呢?
    66、深入理解 promise:promise的三种状态与链式调用
    65.ES6新的特性有哪些?
  • 原文地址:https://www.cnblogs.com/dongsheng/p/2943206.html
Copyright © 2011-2022 走看看