博文

丢硬币:正面朝上的最大连续序列(2009-08-25 16:10:00)

摘要:    //下面是第一次写的,结果不正确! #include<iostream>
#include<ctime>
using namespace std;
int main()
{
 //create sequence:
 static int m=1;
 int digits[1000],max[500],i,maximum;
 srand(time(0));
 for(i=0;i<1000;i++)
  digits[i]=rand()%2;
 for(i=0;i<1000;i++)
  cout<<digits[i];
 cout<<endl<<endl;
 // deal with sequence:
 
 max[1]=1;
 for(i=0;i<1000;)
 {
  if(digits[i]=1)
  {
   max[m]++;
   i++;
  }
  else
  {
   m++;
   i++;
  }
 }
 cout<<"m: "<<m<<endl;
 for(i=0;i<m;i++)
 {
  maximum=(max[i+1]>max[i]? max[i+1]:max[i]);
 }
 cout<<maximum<<endl;  return 0;
}......

阅读全文(1240) | 评论:7

replace文件中字符串【修改1】(2009-08-25 11:59:00)

摘要://Reverse_string.h   #ifndef REVERSE_STRING_H
#define REVERSE_STRING_H #include<string> // #include<cstring>  will cause error!
string   Reverse(string   str)  
{  
  string   S;  
  int   n=str.size();  
  while(n>0)  
  {  
    n--;
       S+=str[n];  
  }  
  return   S;  
} string Convert(string str)
{
  int n=str.size();
  while(n>0)  
  {  
    n--;
    if(str[n]>=65&&str[n]<=90) str[n]+=32;  //convert capital letter into small letter,in order to ignore the form
    //str[n]=(str[n]>90? str[n]+32:str[n]);
  }
  return str;
} string Ignore(string s......

阅读全文(1091) | 评论:1

replace文件中字符串(2009-08-25 10:10:00)

摘要:#ifndef REVERSE_STRING_H
#define REVERSE_STRING_H #include<string> // #include<cstring>  will cause error!
string   Reverse(string   str)  
{  
  string   S;  
  int   n=str.size();  
  while(n>0)  
  {  
    n--;
       S+=str[n];  
  }  
  return   S;  
} string Convert(string str)
{
  int n=str.size();
  while(n>0)  
  {  
    n--;
    if(str[n]>=65&&str[n]<=90) str[n]+=32;  //convert capital letter into small letter,in order to ignore the form
    //str[n]=(str[n]>90? str[n]+32:str[n]);
  }
  return str;
} string Ignore(string str)
{
 int n=str.......

阅读全文(1089) | 评论:0

C++中对浮点数的格式化显示(2009-08-22 15:39:00)

摘要: 在许多应用程序领域中,都需要控制小数点后的小数位,但是浮点数对此不能提供直接的支持。怎样对程序中的浮点数据进行"整齐"地格式化呢?在此我们有一个迂回的方法,先把它们转换为字符串,格式化后以文本形式显示出来。   在日常编程中——包括对话框、关系数据库、金融程序、SMS程序及一切处理数据文件的程序,需要控制小数点后的小数位的情况非常普遍,本文中将要讲解如何用简单的方法来控制小数位,另外,还要揭开字符串及数据精度的一点点小秘密。   问题的引出   如有一个函数,其可接受一个long double参数,并将参数转换为字符串,结果字符串应保留两位小数,例如,浮点值123.45678应该生成"123.45"这样的字符串。表面上看来这是一个意义不大的编程问题,然而,如果真要在实际中派上用场,函数应设计为具有一定弹性,以允许调用者指定小数位数。另外,函数也应该能够处理各种异常情况,如像123.0或123这样的整数。   在开始之前,先看一下编写"优雅"C++代码时的两句"真言":   "真言"1:无论何时需要格式化一个数值,都应先转换为一个字符串。这样可保证每位数刚好占据一个字符。   "真言"2:在需要转换为字符串时,请使用<sstream>库。   转换函数的接口非常简洁:第一个参数是需被格式化的数值;第二个参数代表小数点后显示的小数位,且应该具有一个默认值;返回值为一个string类型: 
string do_fraction(long double value, int decplaces=3);   注意,第二个参数代表的小数位数中包括了小数点,因此,两位小数需要默认值为3.   精度问题   当然,第一步是把long double值转换为一个string,使用标准C++库<sstream>简直是手到擒来。然而,有一件事情必须引起注意,因为某些原因,stringstream对象默认精度为6,而许多程序员错误地把"精度"理解为小数的位数,这是不正确的,精度应指代全部位数。因而,数字1234.56可安全地通过默认精度6来表示,但12345.67会被截断为12345.6.这样的话,如果你有一个非常大的数,如1234567.8,它的结果会静悄悄地转换为科学记数法:1.23457e+06,这显然不是我们想要的。为......

阅读全文(1149) | 评论:0

字符串替换--Debug Error???(2009-08-21 21:46:00)

摘要:#include<iostream>
#include<fstream>
#include<cstdlib>
#include<string>
using namespace std; string replace_all(ifstream infile,string from,string to)
{
 string str;
 infile>>str;
 cout<<"The basic string: "<<str<<endl;
 //replace:
 for(string::size_type pos(0);pos!=string::npos;pos+=to.length())
 {
  if((pos=str.find(from,pos))!=string::npos)
   str.replace(pos,from.length(),to);
  else
   break;
 }  return str;
} int main()
{
 string s,f,t;
 ofstream outfile("IOreplace.dat",ios::out);
 if(!outfile)
 {
  cerr<<"open error!"<<endl;
  exit(1);
 }
 cin>>s;
 outfile<<s;
 outfile.close();  //infile and replace
 ifstream infile("IOreplace.dat",ios::in);
 if(!infile......

阅读全文(1450) | 评论:0

逆转和忽略大小写并且忽略标点(2009-08-21 20:49:00)

摘要://Reverse_string.h
#ifndef REVERSE_STRING_H
#define REVERSE_STRING_H #include<string> // #include<cstring>  will cause error!
string   Reverse(string   str)  
{  
  string   S;  
  int   n=str.size();  
  while(n>0)  
  {  
    n--;
       S+=str[n];  
  }  
  return   S;  
} string Convert(string str)
{
  int n=str.size();
  while(n>0)  
  {  
    n--;
    if(str[n]>=65&&str[n]<=90) str[n]+=32;  //convert capital letter into small letter,in order to ignore the form
    //str[n]=(str[n]>90? str[n]+32:str[n]);
  }
  return str;
} string Ignore(string str)

阅读全文(1194) | 评论:0

逆转字符串(2009-08-21 20:49:00)

摘要:#include   <string>  
  #include   <iostream>  
  using   namespace   std;  
  /*       循环实现  
  string   Reverse(string   str)  
  {  
  string   S;  
  int   n=str.size();  
  while(n>0)  
  {  
  n--;  
  S+=str[n];  
  }  
  return   S;  
  }*/  
  string   Reverse(string   str)  
  {//递归实现  
  static   string   S;  
  static   n=str.size();  
  if(n>0)  
  {  
  n--;  
  S+=str[n]; ......

阅读全文(1285) | 评论:1

ACM--猪的安家(2009-08-03 23:48:00)

摘要:/**********************************************************************************************************************************
猪的安家Andy和Mary养了很多猪。他们想要给猪安家。但是Andy没有足够的猪圈,很多猪只能够在一个猪圈安家。举个例子,假如有16头猪,Andy建了3个
猪圈,为了保证公平,剩下1头猪就没有地方安家了。Mary生气了,骂Andy没有脑子,并让他重新建立猪圈。这回Andy建造了5个猪圈,但是仍然有1头猪
没有地方去,然后Andy又建造了7个猪圈,但是还有2头没有地方去。Andy都快疯了。你对这个事情感兴趣起来,你想通过Andy建造猪圈的过程,知道Andy
家至少养了多少头猪。 输入 输入包含多组测试数据。每组数据第一行包含一个整数n (n <= 10) – Andy建立猪圈的次数,解下来n行,每行两个整数ai, bi( bi <= ai <= 1000),
表示Andy建立了ai个猪圈,有bi头猪没有去处。你可以假定(ai, aj) = 1. 输出 输出包含一个正整数,即为Andy家至少养猪的数目。 样例输入 3
3 1
5 1
7 2 样例输出 16
***********************************************************************************************************************************/ #include<iostream>
#include<cstdlib>
using namespace std;
void pigNums(int n)
{
 int ai[10],bi[10],i=0;
 if(n>10||n<1)
  abort();
 for(i=0;i<n;i++)
 {
  cin>>......

阅读全文(1300) | 评论:3

宏定义的技巧总结(2009-08-03 09:24:00)

摘要:1,防止一个头文件被重复包含 #ifndef COMDEF_H #define COMDEF_H   //头文件内容 #endif 2,重新定义一些类型,防止由于各种平台和编译器的不同,而产生的类型字节数差异,方便移植。 typedef  unsigned char      boolean;     /* Boolean value type. */   typedef  unsigned long int  uint32;      /* Unsigned 32 bit value */ typedef  unsigned short     uint16;      /* Unsigned 16 bit value */ typedef  unsigned char      uint8;       /* Unsigned 8  bit value */   typedef  signed long int    int32;       /* Signed 32 bit value */ typedef  signed short       int16;       /* Signed 16 bit value */ typedef  signed char        int8;        /* ......

阅读全文(976) | 评论:0

计算整数n的p次方:一些小算法(2009-08-02 19:59:00)

摘要:法一: int val=1; while(p--)   val *=n; 法二: int power(int n,int p){  return (p==0)?1:n*power(n,p-1); } 法三: #include <iostream>
using namespace std; template<int N, int P> struct Power {
  enum { val = N * Power<N, P-1>::val };
}; template<int N> struct Power<N, 0> {
  enum { val = 1 };
}; int main() {
  cout << Power<2, 5>::val << endl;  // 32
}  ......

阅读全文(1381) | 评论:2