POJ 3176 Cow Bowling

链接: http://poj.org/problem?id=3176

这道题可以算是dp入门吧。可以用一个二维数组从下向上来搜索从而得到最大值。

优化之后可以直接用一维数组来存。(PS 用一维的时候要好好想想具体应该怎么存,还是有技巧的)

#include<iostream>
#include<cstring>
#include<cmath>
#include<cstdio>
using namespace std;
int dp[355]={0};
int main ()
{
int n,i,j,s=0,a;
cin>>n;
for (i=1; i<=n; i++)
for (j=i; j>=1; j--)
{
cin>>a;
dp[j]=(dp[j]>dp[j-1]?dp[j]:dp[j-1])+a;
//用一维数组更新的时候必须时必须保证更新后的元素在之后同一层dp中不再用到。
if (s<dp[j]) s=dp[j];
}
cout<<s<<endl;
return 0;
}
/*
int map[355][355];
int main ()
{
int n,i,j;
cin>>n;
for (i=0; i<n; i++)
for (j=0; j<=i; j++)
cin>>map[i][j];
for (i=n-2; i>=0; i--)
for (j=0; j<=i; j++)
map[i][j]+=(map[i+1][j]>map[i+1][j+1]?map[i+1][j]:map[i+1][j+1]);
//这是开二维数组,从下向上dp
cout<<map[0][0]<<endl;
return 0;
}
*/

POJ 1674 Sorting by Swapping

链接: http://poj.org/problem?id=1674

题意是有一串数字,问你最少交换多少次可以得到从小到大的排序

我们知道最少交换次数可以用选择排序来求得。但是这道题如果用选择排序的话,必然超时。

其实这道题还是暗藏玄机的。因为n个数正好是1到n。所以如果a[i]==i 就表示该位置已经排好了

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<string>
#define p 3.1415927
using namespace std;
int a[10010]= {0};
int main ()
{
int t,n,i,j;
cin>>t;
while(t--)
{
int s=0;
cin>>n;
for (i=0; i<n; i++)
scanf("%d",a+i);
for (i=0; i<n-1; i++)
if (a[i]!=i+1)//这道题如果用选择排序的话。10000^2。必然超时
//这道题n个数是从1到n。所以加这个判断会适当减时
{
for (j=i+1; j<n; j++)
if (a[j]==i+1)
{
int temp=a[j];
a[j]=a[i];
a[i]=temp;
s++;
}
}
cout<<s<<endl;
}
return 0;
}

POJ 2346 Lucky Tickets

链接: http://poj.org/problem?id=2346

这道题就是一个n位数,左半边相加和有半边相加相等为一个组合,问有多少组合。n位数可以有前导零

由于n最大为10.。想都没想直接打表了。。

不过看discuss里面说这道题可以dp。好神。不过想想也是

这道题还应该再思考思考

//这道题有待提高 用DP来做 以后试试
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int main ()
{
int a[6]={0,10,670,55252,4816030,432457640};
int n;
cin>>n;
cout<<a[n/2]<<endl;
}

这几天做了挺多水题的。为了增快阅读速度吧。还有就是要加快敲代码速度。

这里面几道题目都是相对有点意思的。

POJ 水题若干的更多相关文章

  1. POJ 水题(刷题)进阶

    转载请注明出处:優YoU http://blog.csdn.net/lyy289065406/article/details/6642573 部分解题报告添加新内容,除了原有的"大致题意&q ...

  2. 【POJ水题完成表】

    题目 完成情况 poj1000:A+B problem 完成 poj1002:电话上按键对应着数字.现在给n个电话,求排序.相同的归一类 完成 poj1003:求最小的n让1+1/2+1/3+...+ ...

  3. poj 水题系列

    题目:http://poj.org/problem?id=3006 筛选法求素数 #include <iostream> #include<cstdio> #include&l ...

  4. POJ水题 1298

    #include "stdafx.h" #include <iostream> #include <string> using namespace std; ...

  5. POJ 1488 Tex Quotes --- 水题

    POJ 1488 题目大意:给定一篇文章,将它的左引号转成 ``(1的左边),右引号转成 ''(两个 ' ) 解题思路:水题,设置一个bool变量标记是左引号还是右引号即可 /* POJ 1488 T ...

  6. poj 3080 Blue Jeans(水题 暴搜)

    题目:http://poj.org/problem?id=3080 水题,暴搜 #include <iostream> #include<cstdio> #include< ...

  7. POJ 3984 - 迷宫问题 - [BFS水题]

    题目链接:http://poj.org/problem?id=3984 Description 定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, ...

  8. 【转】POJ百道水题列表

    以下是poj百道水题,新手可以考虑从这里刷起 搜索1002 Fire Net1004 Anagrams by Stack1005 Jugs1008 Gnome Tetravex1091 Knight ...

  9. [POJ 1000] A+B Problem 经典水题 C++解题报告 JAVA解题报告

        A+B Problem Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 311263   Accepted: 1713 ...

随机推荐

  1. MySQL 5.7.9的多源复制

    什么是多源复制? 首先,我们需要清楚 multi-master 与multi-source 复制不是一样的. Multi-Master 复制通常是环形复制,你可以在任意主机上将数据复制给其他主机. M ...

  2. HDU3887 DFS序+ 线段树

    查询树上某个节点的子节点的标号小于其标号的数目. 一个trick是建立线段树之后,从标号小的向标号大的来做更新. 1: #include <cstdio> 2: #include < ...

  3. 非常实用的10个PHP高级应用技巧

    PHP 独特的语法混合了 C.Java.Perl 以及 PHP 自创新的语法.它可以比 CGI或者Perl更快速的执行动态网页.用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML ...

  4. Converting Storyboard from iPhone to iPad

    I found out a kind of solution: Duplicate your iPhone-Storyboard and rename it MainStoryboard_iPad.s ...

  5. java集合类(五)About Map

    接上篇“java集合类(四)About Set” 这次学完Map之后,就剩队列的知识,之后有关java集合类的学习就将告一段落,之后可能会有java连接数据库,I/O,多线程,网络编程或Android ...

  6. C#的配置文件App.config使用总结 - 转

    http://blog.csdn.net/celte/article/details/9749389 首先,先说明,我使用的app.config 配置文件的格式如下: <?xml version ...

  7. [sql server、oracle] 分组取最大值最小值常用sql

    sqlserver2005前: --分组取最大最小常用sql--测试环境if OBJECT_ID('tb') is not null drop table tb;gocreate table tb(  ...

  8. ViewController 优化

    解决问题:部分复杂页面的Controller过于庞大,不利于维护与复用: 复杂的页面大多是基于tableview的页面.复杂页面的代码大致可分为两部分(复杂的View布局用Nib实现的话,一般大家都是 ...

  9. Emmet快速编写CSS样式

    基本的CSS样式编写时,很多样式只需输入首字母即可得到不带属性值的CSS样式,像上面说到的margin. 1.而对于一些带有特定的属性值的CSS样式,只需输入CSS标签与属性值的首字母就可以,比如: ...

  10. codeforces 295E Yaroslav and Points (离线操作+离散化+区间合并)

    参考链接:http://blog.csdn.net/dyx404514/article/details/8817717 写的很详细,这里就不再赘述,附上我的代码. #include <iostr ...