字符串中单词的比较?

如何解决字符串中单词的比较?

是否有一个函数可以用来比较单词的位置无关紧要的字符串?我的意思是“Aaron Jack Brussels”与“Brussels Aaron Jack”等相同。

解决方法

没有标准函数可以做任何接近您目标的事情。您需要编写特定的代码。您可以遍历一个字符串并搜索另一个字符串中的每个单词,反之亦然。

这是一个不修改字符串也不分配任何内存的简单实现:

#include <stdio.h>
#include <string.h>

int countword(const char *w,size_t len,const char *str) {
    size_t i;
    int count = 0;

    for (;;) {
        while (*str == ' ')
            str++;
        if (!*str)
            return count;
        for (i = 1; str[i] && str[i] != ' '; i++)
            continue;
        if (i == len && !memcmp(w,str,len))
            count++;
        str += i;
    }
}

int samewords(const char *s1,const char *s2) {
    const char *p0,*p;

    for (p = s1;;) {
        while (*p == ' ')
            p++;
        if (!*p)
            return 1;
        for (p0 = p++; *p && *p != ' '; p++)
            continue;
        if (countword(p0,p - p0,s1) != countword(p0,s2))
            return 0;
    }
}

int main() {
    if (samewords("Aaron  Jack  Brussels","Brussels Aaron Jack"))
        printf("OK\n");
    if (samewords("Aaron  Jack  Brussels","AaronJackBrussels"))
        printf("Not OK\n");
    if (samewords("Aaron Jack","Aaron Jack Jack"))
        printf("Not OK\n");
    if (samewords("Aaron Jack Brussels","Aaron Jack"))
        printf("Not OK\n");
    if (samewords("John John Doe","John Doe Doe"))
        printf("Not OK\n");    return 0;
}

您可以使用 strspn() 中的 strcspn()<string.h> 将其扩展为处理多个分隔符,例如空格、制表符和换行符:

int countword(const char *w,const char *str) {
    const char *separators = " \t\r\n";
    size_t i;
    int count = 0;

    for (;;) {
        str += strspn(str,separators);
        if (!*str)
            return count;
        i = strcspn(str,separators);
        if (i == len && !memcmp(w,const char *s2) {
    const char *separators = " \t\r\n";
    const char *p0,*p;

    for (p = s1;;) {
        p += strspn(p,separators);
        if (!*p)
            return 1;
        p += strcspn(p0 = p,separators);
        if (countword(p0,s2))
            return 0;
    }
}

注意:我用更通用的版本更新了答案,该版本可以处理重复的单词,例如 "John John Doe" "John Doe Doe",以前的版本会错误地将其视为等效。

,

您真正要做的是创建两组(数学上的)字符串,并尝试比较这些组。不幸的是,未排序的数组(如字符串)不利于这种比较。在 github 上寻找实现集合的 C 库可能是一个更好的起点(我认为 https://github.com/barrust/set 会满足您的需求)。

如果你真的需要一个简单的实现,这应该可以工作并避免分配或字符串修改:

from django.db import models
from django.contrib.auth.models import User
# Create your models here.

class Category(models.Model):
    name = models.CharField(max_length=100)

    def __str__(self):
        return self.name

    class Meta:
        verbose_name = 'Category'
        verbose_name_plural = 'Categories'


class Book(models.Model):
    name = models.CharField(max_length=200)
    description = models.TextField()
    image = models.ImageField()
    price = models.IntegerField()
    category = models.ForeignKey(Category,on_delete=models.SET_NULL,null=True)

    def __str__(self):
        return self.name

class OrderItem(models.Model):
    order_id = models.CharField(max_length=10)
    user = models.ForeignKey(User,null=True)
    book = models.ForeignKey(Book,null=True)

    def __str__(self):
        return self.user.username

class CartItem(models.Model):
    user = models.ForeignKey(User,null=True)

    def __str__(self):
        return self.user.username

,

不是直接的,但是您可以使用 strtok()(或其更有用的可重入表亲 strtok_r())的组合通过“”分隔符分割您的字符串,并使用 strcmp() 来比较每个substring 针对所有其他子字符串。

我的例子非常粗糙(它假设两个字符串集中的子字符串数量相同,并且只检查一个集合与另一个集合),但应该有助于让您走上正确的轨道。

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <stdbool.h>

int main() {
  char stringA[] = "Aaron Jack Brussels";
  char stringB[] = "Brussels Aaron Jack";                                                           
  int numSubStrings = 3;

  char **stringSetA,**stringSetB;
  char *saveStrA,*saveStrB;

  stringSetA = malloc(numSubStrings*sizeof(*stringSetA));
  stringSetB = malloc(numSubStrings*sizeof(*stringSetB));

  // extract first token of each to initialize strtok
  stringSetA[0] = strtok_r(stringA," ",&saveStrA);
  stringSetB[0] = strtok_r(stringB,&saveStrB);

  // loop through the string to extract all other tokens                                            
  for (int i = 1; i < numSubStrings; ++i) {
    stringSetA[i] = strtok_r(NULL,&saveStrA);
    stringSetB[i] = strtok_r(NULL,&saveStrB);
  }

  for (int i = 0; i < numSubStrings; ++i) {
    bool found = false;
    for (int j = 0; j < numSubStrings; ++j) {
      // strcmp == 0 if both strings are equal                                                      
      if (!strcmp(stringSetA[i],stringSetB[j])) {
        found = true;
        break;
      }
    }
    if (!found) printf("Both sets of strings aren't equal!\n");
    else printf("Found %s!\n",stringSetA[i]);
  }
  return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)&gt; insert overwrite table dwd_trade_cart_add_inc &gt; select data.id, &gt; data.user_id, &gt; data.course_id, &gt; date_format(
错误1 hive (edu)&gt; insert into huanhuan values(1,&#39;haoge&#39;); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive&gt; show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 &lt;configuration&gt; &lt;property&gt; &lt;name&gt;yarn.nodemanager.res