罗辑123 发表于 2020-4-28 23:13:33

求c语言大佬教我一下c语言

用指针的方法编写程序,完成如下函数的功能:
int mystrcmp(char *str1,char *str2)——比较两个字符串str1,str2。若str1>str2,返回正数1;str1=str2,返回0;str1<str2,返回负数-1。(注:不能用字符串处理函数strcmp)
求大佬教教这道题怎么做!!!!!

sunrise085 发表于 2020-4-28 23:25:27

本帖最后由 sunrise085 于 2020-4-28 23:40 编辑

#include<stdio.h>
#define MAX 1024
int mystrcmp(char *str1,char *str2){
    int i=0;
    while(str1!='\0'&&str2!='\0')
    {
      if (str1 - str2>0)
            return 1;
      else if (str1 - str2<0)
            return -1;
      i++;
    }
    return 0;
}
int main()
{
      char str1;
      char str2;
      int i = 0;
      unsigned int n;

      printf("请输入第一个字符串:");
      while ((str1 = getchar()) != '\n');

      printf("请输入第二个字符串:");
      i = 0;
      while ((str2 = getchar()) != '\n');

      printf("比较的结果是:%d\n", mystrcmp(str1,str2));

      return 0;
}

jackz007 发表于 2020-4-28 23:40:56

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

int mystrcmp(char * str1 , char * str2)
{
      int ret = * str1 - * str2                                       ;
      while(* str1 && * str2) if((ret = * str1 ++ - * str2 ++)) break ;
      if(ret) ret = (ret > 0) ? 1 : -1                              ;
      return ret                                                      ;
}

main(void)
{
      char s1 , s2                                 ;
      strcpy(s1 , "12345")                                 ;
      strcpy(s2 , s1)                                        ;
      printf("strcmp(s1 , s2) = %d\n" , strcmp(s1 , s2))   ;
      printf("mystrcmp(s1 , s2) = %d\n" , mystrcmp(s1 , s2)) ;
      strcpy(s2 , "12A45")                                 ;
      printf("strcmp(s1 , s2) = %d\n" , strcmp(s1 , s2))   ;
      printf("mystrcmp(s1 , s2) = %d\n" , mystrcmp(s1 , s2)) ;
      strcpy(s2 , s1)                                        ;
      strcpy(s1 , "ABCDE")                                 ;
      printf("strcmp(s1 , s2) = %d\n" , strcmp(s1 , s2))   ;
      printf("mystrcmp(s1 , s2) = %d\n" , mystrcmp(s1 , s2)) ;
}
页: [1]
查看完整版本: 求c语言大佬教我一下c语言