首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C++ >

新人。字符串的有关问题

2013-03-19 
新人求助。字符串的问题编写程序,自动实现非数字字符串的连接与数字字符串相加。函数头文件声明如下:void my

新人求助。字符串的问题
编写程序,自动实现非数字字符串的连接与数字字符串相加。函数头文件声明如下:
void mystrcat(char *p1, char *p2);
例如:(1)有两个字符串“Hello”和“World”,其结果应该是“HelloWorld”;
      (2)有两个字符串“123”和“456”,其结果应该是579;
这个功能该如何实现啊?  主要是第二个, 怎么才能让字符串的数字实现加法啊。
[解决办法]
同新撸过……

可以用栈的思想,判断是全数字还是全字母,
然后数字则char转成int,然后计算。字母就……

或者……用操作符重载……


[解决办法]

引用:
引用:同新撸过……

可以用栈的思想,判断是全数字还是全字母,
然后数字则char转成int,然后计算。字母就……

或者……用操作符重载……

char转换成int不是ASCII码吗?



=。=好吧,原谅我很久不写C++了,最近一直在写Objective-c。C++应该也有将字符转成数字型的函数类的东西……可以去查查C++ 文档。或者就是用栈,理解为一个数组,你将char里的字符,一个一个进入数组。每进入一个,进行一次if,然后再建立一个int,如果此次进入的是数,就,把这个数存入int……【大概吧。我真的很久不写,都忘的差不多了……】
[解决办法]
c++11


bool is_number(std::string const &str)
{
   auto const it = std::find_if(std::begin(str), std::end(str), [](char ch){ return ch < 48 
[解决办法]
 ch > 57;});

   return it == std::end(str);
}

std::string const mystrcat(std::string const &str1, std::string const &str2)
{
  if(is_number(str1) && is_number(str2)){
     double const first = std::stod(str1);
     double const second = std::stod(str2);
     
     return std::to_string(first + second);
  }else{     
     return str1 + str2;
  }
}


c++98
有情好心人士补上
[解决办法]
首先你得有个函数,判断char *的内容是否为纯数字,这个函数会写不?

然后不是纯数字的,strcat

纯数字的,atoi将其转成int,然后相加,然后用sprintf再转回来

[解决办法]

/**
 * @file    mystrcat.c
 * @brief   
 */

#include <ctype.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int isnum(const char *s)
{
    int i, n;

    n = strlen(s);
    for (i = 0; i < n; i++)
        if (!isdigit(s[i]))
            return 0;

    return 1;
}

char * mystrcat(char *s1, const char *s2)
{

    if (isnum(s1) && isnum(s2))
        sprintf(s1, "%d", strtol(s1, NULL, 0) + strtol(s2, NULL, 0));
    else
        strcat(s1, s2);

    return s1;


}

int main(int argc, char *argv[])
{
    char s1[20] = "Hello";
    char s2[] = "World";

    char s3[20] = "123";
    char s4[] = "456";

    printf("%s\n", mystrcat(s1, s2));
    printf("%s\n", mystrcat(s3, s4));

    return 0;
}

热点排行