鱼C论坛

 找回密码
 立即注册
查看: 1112|回复: 2

[已解决]字符串

[复制链接]
发表于 2021-2-1 02:34:39 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题描述】输入两个字符串str和tok。其中tok由若干字符构成,每个字符均可作为一个分隔字符对str进行分隔。
注意:str和tok中均可以包含空格。如果tok含有空格,则空格也作为str的分隔字符。
【输入形式】控制台分两行输入两个字符串str和tok。
【输出形式】分行输出str被分隔后的各字符串。
【样例输入】
jfi,dpf.,jfpe&df-jfpf/□□jfoef$djfo□,pe
,. □/&$-
(上例中“□”代表一个空格)
【样例输出】
jfi
dpf
jfpe
df
jfpf
jfoef
djfo
pe


代码不对  头痛    这一种不对

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
    char str[100],str2[50];
    gets(str);   //输入测试数组
    gets(str2);  //输入间隔符

    int i,j;
    int flag=-1;
    for(i=0;i<strlen(str);i++)     //用双重循环遍历 间隔符数组  如果在测试数组中没有找到,
                                   //输出测试数组对应的字母  如果找到  输出空格
    {
        for(j=0;j<strlen(str2);j++)
        {
            if(str[i]!=str2[j])
                flag=1;
            if(str[i]==str2[j])
                flag=0;

        }


        if(flag==1)
            printf("%c",str[i]);
        if(flag==0)
            printf("\n");
    }

    return 0;
}




这一种也不对


#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
   char *p=NULL,*t=NULL,s[100],d[50];


    gets(s);

    gets(d);

    int i;
    for(i=0;i<strlen(s);i++)
    {
        p=strstr(s,d[i]);
        t=p+strlen(d);
        *p='/0';
        printf("%s\n",s);
    }





    return 0;
}

最佳答案
2021-2-1 19:32:42
用了一个函数封装了分隔符的判断,代码如下:
#include <stdio.h>

char str1[100],str2[50];  //字符串缓冲区

int IsPartition(char c);  //判断分隔符函数

int main(){
  int j = 0;

  gets(str1);
  gets(str2);

  while (str1[j]){  //循环判断,是否到字符串尾'\0'
    if(IsPartition(str1[j])){ //判断第j个字符是不是分割字符
      putchar('\n');
    } else{
      putchar(str1[j]);
    }
    j++;  //后移一个字符
  }
  return 0;
}

//判断是否为分割字符,是分割字符返回1,非分割字符返回0
int IsPartition(char c){
  int i = 0;
  while(str2[i]){
    if(c==str2[i++]) return 1;
  }
  return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-2-1 19:32:42 | 显示全部楼层    本楼为最佳答案   
用了一个函数封装了分隔符的判断,代码如下:
#include <stdio.h>

char str1[100],str2[50];  //字符串缓冲区

int IsPartition(char c);  //判断分隔符函数

int main(){
  int j = 0;

  gets(str1);
  gets(str2);

  while (str1[j]){  //循环判断,是否到字符串尾'\0'
    if(IsPartition(str1[j])){ //判断第j个字符是不是分割字符
      putchar('\n');
    } else{
      putchar(str1[j]);
    }
    j++;  //后移一个字符
  }
  return 0;
}

//判断是否为分割字符,是分割字符返回1,非分割字符返回0
int IsPartition(char c){
  int i = 0;
  while(str2[i]){
    if(c==str2[i++]) return 1;
  }
  return 0;
}

输出样式

输出样式
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-2-1 20:52:01 | 显示全部楼层
推荐使用string来声明字符串,因为string有搜索的功能,fing搜索,substr截取
不然你还得遍历,用法差不多和这个一样
#include <iostream>
#include <string>

int main()
{
    std::string str{ "id=user;pass=632105;role=aaaa" };
    std::string a{};
    printf("请输入需要查询的项目(id,pass,role):\n");
    std::cin>> a;
    if (a == "id") { std::cout << str.substr(str.find("id") + 3, str.find(";") - (str.find("id") + 3)); }
    else { std::cout << "111111111111"; }
    if (a == "pass") { std::cout << str.substr(str.find("pass") + 5, str.find(";", str.find("pass=")) - (str.find("pass") + 5)); }
    if(a=="role"){ std::cout << str.substr(str.find("role") + 5, str.find(";", str.find("role") + 5) - (str.find("role") + 5)); }
    
    

} 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-15 03:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表