鱼C论坛

 找回密码
 立即注册
查看: 1985|回复: 6

[已解决]求助

[复制链接]
发表于 2020-11-15 21:38:58 | 显示全部楼层 |阅读模式

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

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

x
用数组判断是否是回文字符串
最佳答案
2020-11-15 21:45:57
  1. #include <string.h>
  2. #include <stdio.h>
  3. #include <stdbool.h>

  4. void solve(char data[]){
  5.         bool flag = true;
  6.         int len = strlen(data);
  7.         for(int i = 0; i < len/2; ++i){
  8.                 if(data[i] != data[len-i-1]){
  9.                         flag = false;
  10.                         break;
  11.                 }
  12.         }
  13.         if(flag){
  14.                 printf("%s是回文串",data);
  15.         }else printf("%s不是回文串",data);
  16.        
  17. }

  18. int main(void){
  19.         char data[128];
  20.         printf("请输入字符串:");
  21.         gets(data);
  22.         solve(data);
  23.         return 0;
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-11-15 21:45:57 | 显示全部楼层    本楼为最佳答案   
  1. #include <string.h>
  2. #include <stdio.h>
  3. #include <stdbool.h>

  4. void solve(char data[]){
  5.         bool flag = true;
  6.         int len = strlen(data);
  7.         for(int i = 0; i < len/2; ++i){
  8.                 if(data[i] != data[len-i-1]){
  9.                         flag = false;
  10.                         break;
  11.                 }
  12.         }
  13.         if(flag){
  14.                 printf("%s是回文串",data);
  15.         }else printf("%s不是回文串",data);
  16.        
  17. }

  18. int main(void){
  19.         char data[128];
  20.         printf("请输入字符串:");
  21.         gets(data);
  22.         solve(data);
  23.         return 0;
  24. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-15 21:57:54 | 显示全部楼层

能只用一个stdio.h吗?其他两种没学,不允许用,麻烦了,谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-15 21:58:49 | 显示全部楼层
  1. #include <stdio.h>
  2. #include <assert.h>

  3. int huiwen(char *p)
  4. {
  5.         char *q;
  6.         assert(*p != NULL);
  7.         q = p;
  8.         while (*p != '\0')
  9.         {
  10.                 p++;
  11.         }
  12.         p--;
  13.         while (*q != '\0')
  14.         {
  15.                 if (*p == *q)
  16.                 {
  17.                         p--;
  18.                         q++;
  19.                 }
  20.                 else
  21.                         return -1;

  22.         }
  23.         return 1;
  24. }

  25. int main()
  26. {
  27.         int result;
  28.         char p[] = "abcdefgfedcba";
  29.         result = huiwen(p);
  30.         if (result == 1)
  31.                 printf("Yes");
  32.         else
  33.                 printf("No");
  34.         printf("\n");
  35.         return 0;
  36. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-15 22:02:57 | 显示全部楼层
能只用一个stdio.h吗?另一种没学,不允许用,麻烦了,谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-15 22:09:34 | 显示全部楼层
  1. #include <stdio.h>

  2. int length(char data[])
  3. {
  4.         int ans = 0, i = 0;
  5.         while(data[i++]!='\0')++ans;
  6.         return ans;
  7. }

  8. void solve(char data[]){
  9.                 int flag = 1;
  10.         int len = length(data);
  11.         for(int i = 0; i < len/2; ++i){
  12.                 if(data[i] != data[len-i-1]){
  13.                         flag = 0;
  14.                         break;
  15.                 }
  16.         }
  17.         if(flag){
  18.                 printf("%s是回文串",data);
  19.         }else printf("%s不是回文串",data);
  20.         
  21. }

  22. int main(void){
  23.         char data[128];
  24.         printf("请输入字符串:");
  25.         gets(data);
  26.         solve(data);
  27.         return 0;
  28. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-15 22:14:01 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-27 02:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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