| 首页 | 新闻 | 网页 | 设计 | 色彩 | 原创 | 视觉 | 素材 | 动漫 | 酷站 | 策划 | 文案 | 访谈 | 运营 | 编程 | 数据库 | 服务器 | 下载 | 图库 | 
您的位置: 幽幽天空 > 网页 > 编程开发 > CC++教程 > 文章正文 用户登录
用11条标准测验你
Flash Satay: 支持
如何将角度和坐标
AE6.0标准教材的中
判断反向链接质量
用VC程序来创建SQ
MySQL中文参考手册
VB调用C程序的方法
用VB编写标准CGI程
Visual Basic 编程

标准C程式库--问题例--类型 String           

标准C程式库--问题例--类型 String

作者:佚名 来源:不详 更新:2006-8-25 21:05:35 错误报告 我要投稿
Q1:撰写下列函式,其引数为 string 类别

islower - 引数的内容为小写字母,删传回true
isdigit  - 引数的内容为数字,则传回 true
isalphabetic - 引数的内容为大小写字母,则传回 true
isaplhanumeric  - 引数的内容为大小写字母或数字时 ,则传回 true 

A1:须引入 

bool islower(string &text)
{
        for (unsigned int i=0;i        {
                if((text[i] < 'a') || (text[i] >'z')) return false;
        }
        return true;
}

bool isdigit(string &text)
{
        for (unsigned int i=0;i        {
                if((text[i] < '0') || (text[i] > '9')) return false;
        }
        return true;
}

bool isaplhabetic(string &text)
{
        for (unsigned int i=0;i        {
                if(
                    ((text[i] < 'A') || (text[i] >'Z')) &&
                    ((text[i] < 'a') || (text[i] >'z'))
                  ) return false;
        }
        return true;
}

bool isalphanumeric(string &text)
{
        for (unsigned int i=0;i        {
                if(
                    ((text[i] < 'a') || (text[i] >'z')) &&
                    ((text[i] < 'A') || (text[i] >'Z')) &&
                    ((text[i] < '0') || (text[i] >'9'))
                  ) return false;
        }
        return true;
}


--------------------------------------------
Q2:撰写一函式可以判断两字串是否为异位字 ( 长度和字母相同,但顺序不同 )。

A2:须引入 

bool anagram(string s1,string s2)
{
        sort(s1.begin(),s1.end());      //将两字串排序,并比较是否相同
        sort(s2.begin(),s2.end());
        if (s1 == s2) return true;
        return false;
}

--------------------------------------------
Q3:从输入流读入一文字档案,并计算单字个数和平均每个字的长度。

A3:须引入 
void main()
{

        string filename,buffer,word;     //宣告变数
        fstream file;                    //buffer 为资料缓区
        int words=0,allchar=0;           //word 为允许的英文字母
        int start,end;

        //以下为档案读取程序,此程式没有错误处理
        cout << "请输入档案名称:";
        cin >> filename;

        file.open(filename.c_str());
        while (!file.eof())              //读取资料圈
        {
                char ch;
                file.get(ch);
                buffer += ch;
        }
        file.close();

        //合法字母填入
        for (int i=0;i<26;i++)
        {
                word += ('a'+i);
                word += ('A'+i);
        }

        //以下为字母分析
        int len = buffer.length();
        start = buffer.find_first_of(word,0);   //取得第一合法字母位置
        while (start >=0 && start < len)     //检查取得值是否正确
        {
                end = buffer.find_first_not_of(word,start); //取得第一不合法字母位置
                if (end < 0 && end > len) end = len;        //检查取得值是否正确
                allchar += (end-start);                     //加总字数
                words++;                                    //单字数加一
                start = buffer.find_first_of(word,end++);   //在取得下一个合法字母位置
        }                                                   //从 end 後的位置开始
        double average = double(allchar) / words;   //型别转换
        cout << "words = " << words << endl ;       //印出
        cout << "average = " << average << endl;
}
--------------------------------------------
Q4:以继承的方法,重载 " * " 运算子,使它的功能为--将字串重 n 次。例如 " this" * 3 为 "thisthisthis" 。

A4:须引入 

class NString : public string
{
        public:

                NString operator * (unsigned int);
};

NString NString::operator * (unsigned int n)
{
        NString temp;
        while (n!=0)
        {
                temp += c_str();
                n--;
        }
        return temp;
}
--------------------------------------------
Q5:以继承的方法,重载 "- " 运算子,使它的功能为--删除特定字串。如果有重的字串,请删除最前的字串。

A5:须引入 
class NString : public string
{
        public:
                NString operator - (NString);
};

NString NString::operator - (NString str)
{
        NString temp;
        unsigned int pos1 = string::find(str);
        unsigned int len1 = str.length();
        temp.assign(c_str());
        if (pos1 > 0 && pos1 <= length()) temp.erase(pos1,len1);
        return temp;
}
--------------------------------------------
Q6:以继承的方法,重载 " int " 型别转换运算拟,使它能转换字串中的第一个数字。

A6:须引入 
class NString : public string
{
        public:
                operator int();
};

NString::operator int()
{
        string num("0123456789"),temp;  //所有合法的数字
        int val=0;

        //取得第一个数字的位置
        unsigned int start = find_first_of(num,0);
        unsigned int end = find_first_not_of(num,start);
        temp = substr(start,(end-start));

        //转换字串成整数
        for (unsigned int i=0;i        {
              val += (temp[i] - '0');    //利用圈来取得每一个字元的数字
              val *= 10;                    //取得後进位,但个位数会移到十位数
        }                                        //除 10 把个位数拉回
        if ( at(start-1) == '-' ) return -val/10;      //数字前一个位置是否为负号
        return val/10;
}
--------------------------------------------
文章录入:skyuu    责任编辑:skyuu 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    发表评论:
    姓名:  评 分: 1分 2分 3分 4分 5分
     
  • 严禁发表危害国家安全、政治、黄色淫秽等内容的评论。
  • 用户需对自己在使用幽幽天空服务过程中的行为承担法律责任。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表机友个人观点,与本网站立场无关。