不用string.h输入任意五个字符串并比较大小然后输出。我要崩溃了!!子函数检查过没有错误啊!!求助啊,快气死了啊!

GPU小码农 2013-03-21 10:05:29
#include<stdio.h>
#define pf printf
int strcmm(const char *str1,const char *str2)
{
for(;*str1==*str2;str1++,str2++)//
{
if(*str1=='\0')return 0;
}
if( *(unsigned char *)str1 > *(unsigned char *)str2 )
return 1;
else if( *(unsigned char *)str1 < *(unsigned char *)str2 )
return -1;
}
void strcpp(char *s1,char *s2)
{
int i,j;
for(i=0;s1[i]!='\0';i++);
for(j=0;s2[j]!='\0';j++)
s1[i++]=s2[j]; s1[i]='\0';
}
int main(void)
{
char a[5][20],t[20]="";
//char b[][10]={"gfreg","cdwegf"};

int i,j;
//strcpp(t,b[1]);//子函数无错
//puts(t);
// j=strcmm(t,b[0]);
// printf("%d",j);
for(i=0;i<5;i++)
gets(a[i]);//没错for(i=0;i<5;i++)

//for(j=0;j<1;j++)
//puts(a[3]); //scanf("%s",a[i][j]);huo zhe gets(a);
for(i=0;i<4;i++)
for(j=0;j<4-i;j++)

if( strcmm(a[j],a[j+1]) < 0 )
{

strcpp(t,a[j]);
strcpp(a[j],a[j+1]);
strcpp(a[j+1],t);
}

for(i=0;i<5;i++)
puts(a[i]);
}
...全文
432 14 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
ltx36822 2013-03-22
  • 打赏
  • 举报
回复
copy(t,a[j]), 你实际是想把a[j]复制到t, 但你写的复制函数功能是把t复制到a[j],所以就如出现你所说的“如果t不赋初值就会出问题”。把复制函数改下就可以了。
ltx36822 2013-03-22
  • 打赏
  • 举报
回复
把void copy(char from[],char to[]) 改为void copy(char to[],char from[]) 你仔细看下你写的复制函数,在调用的时候顺序搞错了。
大极张三疯 2013-03-22
  • 打赏
  • 举报
回复
楼上正解。。
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
#include<stdio.h> #define pf printf int strbj(char a[],char b[])//字符串比较函数 { int i; for(i=0;a[i]!='\0'||b[i]!='\0';i++) { if(a[i]>b[i])return 1; else if(a[i]<b[i])return -1; else continue; } if(a[i]=='\0'&&b[i+1]!='\0') return -1; else if ( a[i+1]!='\0'&&b[i]=='\0' ) return 1; else return 0; } void copy(char from[],char to[])//字符串复制函数 { int i=0; while(from[i]!='\0') {to[i]=from[i];i++;} to[i]='\0'; } int main(void) { /*测试子函数用的代码char a[2][20]={"abq","ab"}; int i; i=strbj(a[0],a[1]); pf("%d",i);测试用的*/ char a[5][20],t[20]=""; //如果t不赋初值就会出问题 int i,j; for(i=0;i<5;i++) gets(a[i]); for(i=0;i<4;i++) for(j=0;j<4-i;j++) if( strbj(a[j],a[j+1]) < 0 ) { copy(t,a[j]); copy(a[j],a[j+1]); copy(a[j+1],t); } for(i=0;i<5;i++) pf("%s\n",a[i]); }请问这个还乱吗?请如实说,谢谢!!感激不尽!!
atinysix 2013-03-21
  • 打赏
  • 举报
回复
代码好乱,楼主贴源码上来
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
又改了一下,但还是不行
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
#include<stdio.h> #define pf printf int strbj(char a[],char b[]) { int i; for(i=0;a[i]!='\0'||b[i]!='\0';i++) { if(a[i]>b[i])return 1; else if(a[i]<b[i])return -1; else continue; } if(a[i]=='\0'&&b[i+1]!='\0') return -1; else if ( a[i+1]!='\0'&&b[i]=='\0' ) return 1; else return 0; } void copy(char from[],char to[]) { int i=0; while(from[i]!='\0') {to[i]=from[i];i++;} to[i]='\0'; } int main(void) { /*char a[2][20]={"abq","ab"}; int i; i=strbj(a[0],a[1]); pf("%d",i);测试用的*/ char a[5][20],t[20]=""; //如果t不赋初值就会出问题 int i,j; for(i=0;i<5;i++) gets(a[i]); for(i=0;i<4;i++) for(j=0;j<4-i;j++) if( strbj(a[j],a[j+1]) < 0 ) { copy(t,a[j]); copy(a[j],a[j+1]); copy(a[j+1],t); } //printf("cdvc"); for(i=0;i<5;i++) pf("%s\n",a[i]);//puts(a[i]); }
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
#include<stdio.h> #define pf printf int strcmm(const char *str1,const char *str2) { for(;*str1==*str2;str1++,str2++)// { if(*str1=='\0')return 0; } if( *(unsigned char *)str1 > *(unsigned char *)str2 ) return 1; else if( *(unsigned char *)str1 < *(unsigned char *)str2 ) return -1; } void copy(char from[],char to[]) { int i=0; while(from[i]!='\0') {to[i]=from[i];i++;} to[i]='\0'; } int main(void) { char a[5][20],t[20]=""; int i,j; for(i=0;i<5;i++) gets(a[i]); for(i=0;i<4;i++) for(j=0;j<4-i;j++) if( strcmm(a[j],a[j+1]) < 0 ) { copy(t,a[j]); copy(a[j],a[j+1]); copy(a[j+1],t); } for(i=0;i<5;i++) puts(a[i]); } 帮忙看看这个吧,修改过了的,可还是不行
derekrose 2013-03-21
  • 打赏
  • 举报
回复
注释有点乱,去掉吧再重整理一下,看的很麻烦
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
但是子函数我测试过,没有错啊
ForestDB 2013-03-21
  • 打赏
  • 举报
回复
void strcpp(char *s1,char *s2) { int i,j; for(i=0;s1[i]!='\0';i++); 这个分号干嘛? for(j=0;s2[j]!='\0';j++) s1[i++]=s2[j]; s1[i]='\0'; 这两个语句属于哪个循环? }
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
求解答疑惑啊
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
快崩溃了!!调了好久了
GPU小码农 2013-03-21
  • 打赏
  • 举报
回复
编译无错,输入完五个字符串后就不能运行了
资源下载链接为: https://pan.quark.cn/s/abbae039bf2a 在计算机视觉领域,实时目标跟踪是许多应用的核心任务,例如监控系统、自动驾驶汽车和无人机导航等。本文将重点介绍一种在2017年备受关注的高效目标跟踪算法——BACF(Boosted Adaptive Clustering Filter)。该算法因其卓越的实时性和高精度而脱颖而出,其核心代码是用MATLAB编写的。 BACF算法全称为Boosted Adaptive Clustering Filter,是基于卡尔曼滤波器改进的一种算法。传统卡尔曼滤波在处理复杂背景和目标形变时存在局限性,而BACF通过引入自适应聚类和Boosting策略,显著提升了对目标特征的捕获和跟踪能力。 自适应聚类是BACF算法的关键技术之一。它通过动态更新特征空间中的聚类中心,更准确地捕捉目标的外观变化,从而在光照变化、遮挡和目标形变等复杂情况下保持跟踪的稳定性。此外,BACF还采用了Boosting策略。Boosting是一种集成学习方法,通过组合多个弱分类器形成强分类器。在BACF中,Boosting用于优化目标检测性能,动态调整特征权重,强化对目标识别贡献大的特征,从而提高跟踪精度。BACF算法在设计时充分考虑了计算效率,能够在保持高精度的同时实现速实时的目标跟踪,这对于需要速响应的应用场景(如视频监控和自动驾驶)至关重要。 MATLAB作为一种强大的数学计算和数据分析工具,非常适合用于算法的原型开发和测试。BACF算法的MATLAB实现提供了清晰的代码结构,方便研究人员理解其工作原理并进行优化和扩展。通常,BACF的MATLAB源码包含以下部分:主函数(实现整个跟踪算法的核心代码)、特征提取模块(从视频帧中提取目标特征的程序)、聚类算法(实现自适应聚类过程)、Boosting算法(包含特征权重更新的代
内容概要:本书《Deep Reinforcement Learning with Guaranteed Performance》探讨了基于李雅普诺夫方法的深度强化学习及其在非线性系统最优控制中的应用。书中提出了一种近似最优自适应控制方法,结合泰勒展开、神经网络、估计器设计及滑模控制思想,解决了不同场景下的跟踪控制问题。该方法不仅保证了性能指标的渐近收敛,还确保了跟踪误差的渐近收敛至零。此外,书中还涉及了执行器饱和、冗余解析等问题,并提出了新的冗余解析方法,验证了所提方法的有效性和优越性。 适合人群:研究生及以上学历的研究人员,特别是从事自适应/最优控制、机器人学和动态神经网络领域的学术界和工业界研究人员。 使用场景及目标:①研究非线性系统的最优控制问题,特别是在存在输入约束和系统动力学的情况下;②解决带有参数不确定性的线性和非线性系统的跟踪控制问题;③探索基于李雅普诺夫方法的深度强化学习在非线性系统控制中的应用;④设计和验证针对冗余机械臂的新型冗余解析方法。 其他说明:本书分为七章,每章内容相对独立,便于读者理解。书中不仅提供了理论分析,还通过实际应用(如欠驱动船舶、冗余机械臂)验证了所提方法的有效性。此外,作者鼓励读者通过仿真和实验进一步验证书中提出的理论和技术。

70,022

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧