/*编写一个程序,读入用户输入的一串先序遍历字符串,根据此字符串建立一个二叉树(以指针方式存储)。

例如如下的先序遍历字符串: abc##de#g##f### 其中 # 表示的是空格,空格字符代表空树。

建立起此二叉树以后,再对二叉树进行中序遍历,输出遍历结果。

输入格式
共一行,包含一个字符串,表示先序遍历字符串。

输出格式
共一行,输出将输入字符串建立二叉树后中序遍历的序列,字符之间用空格隔开。

注意,输出中不用包含 #。

数据范围
输入字符串长度不超过 100
,且只包含小写字母和 #。

输入样例:
abc##de#g##f###
输出样例:
c b e g d f a*/

#include<iostream>
using namespace std;
#include<string>
 int k;//此时二叉树所在的位置

 string str;
 void dfs()
 {
    if(str[k]=='#')
    {
        k++;//往后走一个位置
        return;//返回上一层递归
    }
    char r=str[k++];//用r来存一下所在位置的字母
    dfs();
    cout<<r<<" ";//中序输出
    dfs();
 }

 int main()
 {
    cin>>str;
    dfs();
    return 0;
 }

/*给定一个长度为 n
的数组 a1,a2,…,an

现在,要将该数组从中间截断,得到三个非空子数组。

要求,三个子数组内各元素之和都相等。

请问,共有多少种不同的截断方法?

输入格式
第一行包含整数 n

第二行包含 n
个整数 a1,a2,…,an

输出格式
输出一个整数,表示截断方法数量。

数据范围
前六个测试点满足 1≤n≤10

所有测试点满足 1≤n≤105
,−10000≤ai≤10000

输入样例1:
4
1 2 3 3
输出样例1:
1
输入样例2:
5
1 2 3 4 5
输出样例2:
0
输入样例3:
2
0 0
输出样例3:
0*/

#include<iostream>
using namespace std;
const int N=10010;
int a[N],s[N];
int main()
{
   int n;
   cin>>n;
   for(int i=1;i<=n;i++)
   {
      cin>>a[i];
   }
   for(int i=1;i<=n;i++)
   {
      s[i]=s[i-1]+a[i];
   }
   long long cnt=0,res=0;
   if(s[n]%3)cout<<"0"<<endl;
   else{

      for(int j=2;j<=n;j++)
      {
         if(s[j-1]==s[n]/3)cnt++;
         if(s[j]==s[n]/3*2)res+=cnt;
      }
   }
   cout<<res<<endl;
}
posted on 2023-04-16 01:13  许七安gyg  阅读(50)  评论(0编辑  收藏  举报
$(document).ready(function() { // 禁止右键 $(document).bind("contextmenu", function(){return false;}); // 禁止选择 $(document).bind("selectstart", function(){return false;}); // 禁止Ctrl+C 和Ctrl+A $(document).keydown(function(event) { if ((event.ctrlKey&&event.which==67) || (event.ctrlKey&&event.which==86)) { //alert("对不起,版权所有,禁止复制"); return false; } }); });