自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(19)
  • 收藏
  • 关注

原创 POSIX多线程程序设计 工作流例程2

之前的例程有说到超出工作单元数量的输入数据会使得整个进程进入死锁状态,然后改进了一下,让用户可以选择是获取数据再加入新的数据还是放弃加入新数据。还有一点就是,我认为pipe_t中的mutex锁是多余的,因为其他线程只会修改工作单元内部的数据,而并不会影响工作流pipe链表的结构,而更改pipe_t的数据的只有pipe_result和pipe_start这两个函数,但是这两个函数只会在主

2016-03-25 16:13:17 489

原创 POSIX多线程程序设计_流水线工作例程

#include#include "errors.h"typedef struct stage_tag{ //流水线的工作单元结构体 pthread_mutex_t mutex; //保护当前工作单元数据的互斥锁 pthread_cond_t avail; //等待当前工作单元存储数据可用的条件变量 pthread_cond_t ready; //等待当前工作单元可处理

2016-03-25 14:50:22 1022

原创 多线程

#include#include#include "errors.h"typedef struct alarm_tag{ //单个闹钟结构体,链表形式存储 struct alarm_tag *link; //链表的下一个节点 int seconds; //闹钟响铃所需经过的秒数(从创建时刻为起点) time_t time; //闹钟响铃的UNIX时间(从1970年1月1日0时0分0

2016-03-25 01:17:06 404

原创 控制台小游戏之贪吃蛇

贪吃蛇和俄罗斯方块差不多,都是另起一个线程监听键盘输入,然后就是不断刷新。(控制台跳屏的感觉真不爽,感觉要瞎了)很简单的就一个snake类和一个game类外加辅助的random_food可调用对象类。用枚举变量代表snake当前的行进方向point_and_dir.h#ifndef _POINT_AND_DIR_H#define _POINT_AND_DIR_

2015-12-27 23:46:44 682

原创 控制台小游戏之俄罗斯方块

因为最近在学多线程,用的C++新标准的thread库,就尝试简单用了一下,写进俄罗斯方块里监听键盘输入。基本的思路就是用一个类代表一种方块,方块类中用一个坐标pos表示方块位置,然后一个坐标数组offset代表方块的各个小方格相对于pos的偏移量。加上两个生成随即数的可调用对象的类来随机生成方块。棋子类base_cube是个虚基类,另外有七个类都继承自base_cube :O_cu

2015-12-27 23:29:02 773

原创 控制台小游戏之五子棋

五子棋用了两个类,一个棋盘类ChessBoard和一个玩家类Player,然后用一个game类包装一下,实现一些游戏的基本操作。ChessBoard.h:#ifndef _CHESS_BOARD_H#define _CHESS_BOARD_H#include#include#includeclass ChessBoard{public: ChessBoard(std::

2015-12-27 22:58:33 677

原创

大三第一个学期也过去了,专业课也是水水的准备考试,这学期终于啃完了C++Primer这本大部头,C++学了这么久也才感受到了皮毛而已,不过学习C++的过程还是十分享受的。最近买的书也多:Effective C++,Inside the C++ Object Mode,鸟哥的linux私房菜,TCP/IP详解(卷一),STL源码剖析。现在的水看STL的源码还是觉得比较晦涩难懂。Inside C+

2015-12-27 22:29:28 383

原创 POJ 2029

DescriptionSeiji Hayashi had been a professor of the Nisshinkan Samurai School in the domain of Aizu for a long time in the 18th century. In order to reward him for his meritorious career in edu

2015-08-15 08:48:47 486

原创 UVA 10954

Description///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

2015-08-15 08:36:27 509

原创 CSUOJ 赌神的战斗

Description老千可以有很多,但是赌神,只能有一个!2015届赌神争霸赛现在在湖南长沙淹鱼塘隆重开幕,2名赌神候选者已经准备就绪。已知赌神争霸的规则如下:每个赌神候选者有一个他特制的骰子和特制的战甲,分别能给他提供攻击力和生命值。两个赌神候选者交手的流程如下:1,2号赌神候选者分别投掷自己的骰子,点数相同则重新投,否则点数大的赌神候选者会对点数小的造成他们点数差

2015-08-13 13:04:36 621

原创 HDU 1358 Period

DescriptionFor each prefix of a given string S with N characters (each character has an ASCII code between 97 and 126, inclusive), we want to know whether the prefix is a periodic string. That is,

2015-08-12 16:57:08 362

原创 POJ 2406 Power String

DescriptionGiven two strings a and b we define a*b to be their concatenation. For example, if a = "abc" and b = "def" then a*b = "abcdef". If we think of concatenation as multiplication, exponen

2015-08-12 16:47:29 478

原创 HDU 1686:Oulipo

DescriptionThe French author Georges Perec (1936�1982) once wrote a book, La disparition, without the letter 'e'. He was a member of the Oulipo group. A quote from the book: Tout avait Pair no

2015-08-12 16:40:15 424

原创 HDU 1711 Number Sequence

DescriptionGiven two sequences of numbers : a[1], a[2], ...... , a[N], and b[1], b[2], ...... , b[M] (1 <= M <= 10000, 1 <= N <= 1000000). Your task is to find a number K which make a[K] = b[1], a

2015-08-12 16:31:46 328

原创 CSUOJ:K swap operation

Description最近Mr.Q想要只通过一种操作来对序列进行升序排序,该操作是“交换相邻的两个数”,聪明的Mr.Q总是会选择最优的方法进行操作,也就是说他使用的交换次数是最少的。比如对于对于序列:2 3 1 4Mr.Q会使用2次交换操作。而对于序列:4 3 2 1Mr.Q会使用6次交换操作。请你构造一个1~N的

2015-08-12 16:13:34 518

原创 CSUOJ:经营小卖部

Description      暑假很多店都关门了,还坚持营业的店可以收揽大多数客户。看准了这个商机,你和小伙伴们打算集资开一个小卖部。      你们总共集资了X元,可以用来购置商品和其他配置。每个商品有自己的进价和售价,你可以根据自己的要求以进价购入任意数量的商品,并全部以售价卖出。可是因为供货商暑期停止供货,所以你们只能使用X元提前买好商品并在暑假卖掉,

2015-08-12 15:58:06 1344

原创 CSUOJ:集训队组队计划

Description      经过1个月的训练,集训工作组决定让大家组队参加组队赛。为了让每一队内部水平尽量平均,集训工作组希望能令每个队能力最强的队员和能力最弱的队员的能力值差值的最大值尽量小。已知每个队由三个人组成,一个人不能加入多个队伍,现在有N个队员,能力分别为a1,a2...an,要从中选出3M个队员组成M支队。请问这M支队伍中,能力差值的最大值最小为多少

2015-08-12 15:39:57 481

转载 CodeForces327C

这是今天做的一道快速幂的题,看完题目之后用笔在草稿纸上写写就能分析出来其中的数学公式 ans=(Σpow(2,i)*(pow(2,k*len)-1)/(pow(2,len)-1))%M  但是代码交上去之后一直WA,总是不明白哪里错了,WA了快十次实在不知道怎么改了,于是上网搜了下题解,发现了新大陆!!在刚才写的公式里面有一个除法求模的运算,之前的代码我就直接相除取模了ans=(a

2015-07-26 15:42:33 784

原创 POJ 1008 Maya Calendar

//CODE//#include<iostream>#include<string>using namespace std;int foo(string &s,int day){ if(s=="pop")return 0*20+day+1; if(s=="no")return 1*20+day+1; if(s=="zip")return 2*20+day+1; if(s=="zotz")return 3*20+day+1; if(s=="tzec")

2015-07-20 15:08:07 514 4

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除