NYOJY 491 幸运三角形
描述
话说有这么一个图形,只有两种符号组成(‘+’或者‘-’),图形的最上层有n个符号,往下个数依次减一,形成倒置的金字塔形状,除第一层外(第一层为所有可能情况),每层形状都由上层决定,相邻的符号相同,则下层的符号为‘+’,反之,为‘-’;如下图所示(n = 3 时的两种情况):

如果图中的两种符号个数相同,那这个三角形就是幸运三角形,如上图中的图(2).
- 输入
- 有多组测试数据(少于20组)。
每行含一个整数n(0<n<20)。 - 输出
- 输出相应的幸运三角形个数。
- 样例输入
-
3
4 - 样例输出
-
4
6///排列组合第一行,然后直接寻找是否相等
#include <iostream>
#include <cstdio>
#include <cstring>
#define N 1010
#define MOD 1000000007
using namespace std;
int n,m,ans[];
int a[];///待排列的数存储在此
bool vis[];
int p[N][N],k;
int sum,num,tot;
void dfs(int cnt)///按字典序输出n个数选m个数的所有排列
{
if(cnt==m)
{
for(int i=; i<m; i++)
{
if(ans[i] == ans[i+] && i+ < m)
p[][k] = ,sum++;
else
p[][k] = ;
k++;
if(ans[i] == )
sum++;
}
int c = ;
while(c < m)
{
k = ;
for(int i = ; i < m - c + ; i++)
{
if(p[c-][i] == p[c-][i+] && i+ < m - c + )
p[c][k] = ,sum++;
else
p[c][k] = ;
k++;
}
c++;
}
if(sum == num)
tot++;
k = ;
// for(int i=0; i<m; i++)
// cout<<ans[i]<<"***";
// cout<<endl;
// for(int i = 1; i < m; i++)
// {
// for(int j = 0 ; j < m-i; j++)
// cout<<p[i][j]<<"***";
// cout<<endl;
// }
// cout<<sum<<" "<<num<<endl;
sum = ;
return ;
}
for(int i=; i<n; i++)
{
ans[cnt]=a[i];
dfs(cnt+);
}
}
int main()
{
while(cin>>m)
{
k = ;
n = ;
sum = ;
tot = ;
num = m * (m + );
if(num % )
{
cout<<<<endl;
continue;
}
else
num /= ;
fill(vis,vis+,);
a[] = ;
a[] = ;
dfs();
cout<<tot<<endl;
}
return ;
}TLE
纯粹dfs,回溯还未入门,不过如果应试的话完全可以打表,毕竟数据量不是太大。
///排列组合第一行,然后直接寻找是否相等
#include <iostream>
#include <cstdio>
#include <cstring>
#define N 1010
#define MOD 1000000007
using namespace std;
int n,m,ans[];
int a[];///待排列的数存储在此
bool vis[];
int p[N][N],k;
int sum,num,tot;
void dfs(int cnt)///按字典序输出n个数选m个数的所有排列
{
if(cnt==m)
{
for(int i=; i<m; i++)
{
if(ans[i] == ans[i+] && i+ < m)
p[][k] = ,sum++;
else
p[][k] = ;
k++;
if(ans[i] == )
sum++;
}
int c = ;
while(c < m)
{
k = ;
for(int i = ; i < m - c + ; i++)
{
if(p[c-][i] == p[c-][i+] && i+ < m - c + )
p[c][k] = ,sum++;
else
p[c][k] = ;
k++;
}
c++;
}
if(sum == num)
tot++;
k = ;
// for(int i=0; i<m; i++)
// cout<<ans[i]<<"***";
// cout<<endl;
// for(int i = 1; i < m; i++)
// {
// for(int j = 0 ; j < m-i; j++)
// cout<<p[i][j]<<"***";
// cout<<endl;
// }
// cout<<sum<<" "<<num<<endl;
sum = ;
return ;
}
for(int i=; i<n; i++)
{
ans[cnt]=a[i];
dfs(cnt+);
}
}
int main()
{
for(m = ; m < ; m++)
//while(cin>>m)
{
k = ;
n = ;
sum = ;
tot = ;
num = m * (m + );
if(num % )
{
cout<<<<",";
continue;
}
else
num /= ;
fill(vis,vis+,);
a[] = ;
a[] = ;
dfs();
cout<<tot<<",";
}
return ;
}打表过了
回溯才是正解,可以减掉重复计算的值,但是自己没搞懂,留下正解先
///边回溯边计算,避免重复计算
#include"iostream"
#include<cstring>
#include<stdio.h>
#include<time.h>
using namespace std;
typedef unsigned char uchar; //char cc[2]={'+','-'}; //便于输出
int n, //第一行符号总数
half, //全部符号总数一半
counter; //1计数,即 '-' 号计数 char **p; //符号存储空间
long sum; //符合条件的三角形计数 //t,第一行第 t个符号
void Backtrace(int t)
{
int i, j; if( t > n )
sum++;
else
{
for(i=; i<; ++i) //只取 0('+') 或者 1('-')
{
p[][t] = i; //第一行第 t个符号
counter += i; //'-'号统计
for(j=; j<=t; ++j) //当第一行符号 >=2时,可以运算出下面行的某些符号(第一行有几个数就可以相应往下计算几行,每次计算过的就不用重复计算)
{
p[j][t-j+] = p[j-][t-j+]^p[j-][t-j+];//通过异或运算下行符号
counter += p[j][t-j+];
}
if( (counter <= half) && ( t*(t+)/ - counter <= half) )//若符号统计未超过半数,并且另一种符号也未超过半数
Backtrace(t+); //在第一行增加下一个符号
//回溯,判断另一种符号情况
for(j=; j<=t; ++j)
counter -= p[j][t-j+];
counter -= i;
}
}
} int main()
{
while(scanf("%d", &n) != EOF)
{
counter = ;
sum = ;
half = n*(n+)/; if( half% == )//总数须为偶数,若为奇数则无解
{
half /= ;
p = new char *[n+];
for(int i=; i<=n; ++i)
{
p[i] = new char[n+];
memset(p[i], , sizeof(char)*(n+));
}
Backtrace();
}
printf("%d\n", sum);
}
return ;
}回溯正解
http://www.cnblogs.com/dongsheng/archive/2013/06/16/3138607.html
NYOJY 491 幸运三角形的更多相关文章
- NYOJ 491 幸运三角形
幸运三角形 import java.util.Scanner; public class Main{//搜索 static int sum=0,n; public static void main(S ...
- nyoj 幸运三角形
幸运三角形 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 话说有这么一个图形,只有两种符号组成(‘+’或者‘-’),图形的最上层有n个符号,往下个数依次减一,形成倒 ...
- 幸运三角形 南阳acm491(dfs)
幸运三角形 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 话说有这么一个图形,只有两种符号组成(‘+’或者‘-’),图形的最上层有n个符号,往下个数依次减一,形成倒 ...
- NYOJ--491--dfs(打表水过)--幸运三角形
/* Name: NYOJ--491--幸运三角形 Author: shen_渊 Date: 15/04/17 16:26 Description: DFS超时,深搜出第一行的所有情况,计算之后打表水 ...
- nyoj--491--幸运三角形(dfs)
幸运三角形 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 话说有这么一个图形,只有两种符号组成('+'或者'-'),图形的最上层有n个符号,往下个数依次减一,形成倒置的 ...
- 用CSS绘制箭头等三角形图案 [译]
最近重新设计了我的网站,准备添加tooltips提示信息效果.实现很容易,但我想要让提示功能具有三角形的指示图标.当我重新思考想要所设计的每个图标颜色都随心所欲的时候,采用图片那就是一场灾难.幸运的是 ...
- LearnOpenGL 你好,三角形[转]--附源码
原地址:你好,三角形 你好,三角形 原文 Hello Triangle 作者 JoeyDeVries 翻译 Django 校对 Geequlim 译注 在学习此节之前,建议将这三个单词先记下来: 顶点 ...
- OpenGL学习笔记(二)画三角形
目录 渲染管线(Graphics Pipeline) 编码实现 顶点数据 顶点缓冲对象(VBO) 顶点着色器 编译着色器 片段着色器 着色器程序 链接顶点属性 顶点数组对象 最终绘制三角形 索引缓冲对 ...
- canvas快速绘制圆形、三角形、矩形、多边形
想看前面整理的canvas常用API的同学可以点下面: canvas学习之API整理笔记(一) canvas学习之API整理笔记(二) 本系列文章涉及的所有代码都将上传至:项目代码github地址,喜 ...
随机推荐
- 使用CXF发布WebService
这里普及一下WebService和cxf的知识.关于webservice和cxf: WebService.各种提供服务的组件 .企业总线.通讯总线(ESB)CXF:是一个SOA框架,Axi ...
- SQL SERVER 2005 DBCC IND命令说明
每天笑一笑,烦恼少一倍 轻松一笑!狗狗被调戏:http://947kan.com/video/player-52952-0-0.html ------------------------------- ...
- ThinkPHP 3.2.3(四)架构之多层MVC
一.模型(Model)层 1.ThinkPHP支持多层Model,不同的模型层都继承自系统的Model类. 2.模型的多层通过目录结构和命名规范区分. 例如:在某个项目设计中需要区分数据层.逻辑层 ...
- .NET小细节
1.equals()和运算符==的区别 C#中有两种不同的相等:引用相等和值相等.值相等是两个对象包含相同的值:引用相等是两个对象引用的是同一个对象. “==”操作符比较的是两个变量的值是否相等,或两 ...
- C# 扩展类
C# 中提供一个非常实用的供能,扩展方法(Extension method) 扩展方法是通过额外的静态方法扩展现有的类型.通过扩展方法,可以对已有类型做自己想做的相关扩展.方法:定义静态类,扩展方法也 ...
- iOS系统网络抓包方法
转到自己的博客收藏. 1. 网络共享 + 可视化抓包工具 基本原理 原理比较简单,ios设备通过代理方式共享连接mac电脑的无线网卡,使用抓包工具抓包,然后进行分析(我们推荐使用Wireshark,在 ...
- 【转载】桥接Microsoft Word和浏览器
原文链接地址: http://www.infoq.com/cn/articles/convert-microsoft-word-to-html?utm_campaign=rightbar_v2& ...
- bzoj2141 树状数组套Treap树
题目大意是在能够改变两个数的位置的情况下计算逆序对数 这因为是动态记录逆序对 本来单纯逆序对只要用树状数组计算即可,但这里因为更新,所以利用TReap树的删点和增加点来进行更新 大致是把每个树状数组所 ...
- Makefile 一点一滴(一)—— 从最简单的makefile模板写起
我在网上先找了一个最简单的makefile. 建立一个 TestCpp 目录,简单的写几行代码,命名为“TestCpp.cpp”,然后和这个最简单的 makefile 一起扔进去: TestCpp.c ...
- STL 内存释放
C++ STL 中的map,vector等内存释放问题是一个很令开发者头痛的问题,关于 stl内部的内存是自己内部实现的allocator,关于其内部的内存管理本文不做介绍,只是 介绍一下STL内存释 ...