再做决定之前,我还是做好自己该做的。我不希望几年后会悔恨自己为什么在最该努力的时候不愿意吃苦。尊敬的女王陛下,请接题:

一.题目:有已按升序排好顺序的字符串a,编写程序将字符串s中的每个字符按升序的规则插到字符串a中,最后输出”abdefghjkmnptwy”。

二.思路:既然是已经排好序的,就用二分法查找的思想

将字符串s中的每个字符依次作为key拿来和字符串a做比较并且插入

三.程序

 #include <stdio.h>
#include <string.h> #define SIZE 50 void InsertStr(char *s,char *a,int low,int high)
{
int mid = ; while(*a)
{
mid = (low+high)/; //当mid位置字符<*a<mid+1位置字符或者mid位置字符等于*a时
if((s[mid]<*a) && (s[mid+]>*a) || s[mid]==*a)
{
for(int j=mid+;*(s+j);j++)
{
s[j] = *a;//把*a插入到字符串s中mid+1的位置
s[j+]=s[j+];//并且字符串s从mid+2开始的位置全部往后挪一个位置
high = high +;//若每插入一个*a字符,则右区间要加1
}
}
else if(s[mid] >*a)
{ //若mid位置对应的字符大于*a,则右区间变为mid
high = mid;
InsertStr(s,a,low,high);
}
else if(s[mid] <*a)
{ //若mid位置对应的字符小于*a,则左区间变为mid
low = mid;
InsertStr(s,a,low,high); } a++;
} } int main(void)
{
char s[SIZE]={};
char a[SIZE]={}; printf("Please input the s string:\n");
scanf("%s",s);
printf("Please input the a string:\n");
scanf("%s",a); InsertStr(s,a,,strlen(s));
printf("%s",s); return ; }

三.编译运行

程序出错

四.分析问题

1.在插入字符串那个if条件语句里,犯了一个错误:往后面挪的时候,前面的已经把后面的覆盖了,比如a[6]=a[5],然后a[7]=a[6],看到没,这个时候a[6]已经被a[5]覆盖了,它再往后挪都不是自己原来的值了,所以要从最后面开始挪,这样才不会被覆盖。

2.*a可以肯定的是插在s[mid+1]的位置,所以直接s[mid+1]=*a;//把*a插入到字符串s中mid+1的位置就可以了,不然s[mid+1]的值会被*a覆盖

3.每插入一个字符都需要重新获取high

五.程序

 #include <stdio.h>
#include <string.h> #define SIZE 50 void InsertStr(char *s,char *a,int low,int high)
{
int mid = ; while(*a)
{ mid = (low+high)/; //当mid位置字符<*a<mid+1位置字符或者mid位置字符等于*a时
if((s[mid]<*a) && (s[mid+]>*a) || s[mid]==*a)
{
for(int j=strlen(s)-;j>=mid+;j--)
{
s[j+]=s[j];//并且字符串s从mid+2开始的位置全部往后挪一个位置
}
s[mid+]=*a;//把*a插入到字符串s中mid+1的位置 }
else if(s[mid] >*a)
{ //若mid位置对应的字符大于*a,则右区间变为mid
high = mid;
InsertStr(s,a,low,high);
}
else if(s[mid] <*a)
{ //若mid位置对应的字符小于*a,则左区间变为mid
low = mid;
InsertStr(s,a,low,high); } a++;
high =strlen(s);//每个字符串a都要重新获取s字符串的长度
} } int main(void)
{
char s[SIZE]={};
char a[SIZE]={}; printf("Please input the s string:\n");
scanf("%s",s);
printf("Please input the a string:\n");
scanf("%s",a); InsertStr(s,a,,strlen(s));
printf("%s",s); return ; }

还是无法跳出InsertStr()函数,突然记起来要在函数末尾加一个return

        a++;
high =strlen(s);//每个字符串a都要重新获取s字符串的长度
} return;
}

真的可以跳出来了,但是却还是有问题,现在这样的运行结果是

六.到底哪里出了问题呢?

七.给出网上的解答版本

 #include<stdio.h>
#include<string.h>
void main()
{
char a[]="bdfhjmptwy"; //升序
char s[ ]="ganke";
char *p1=a,*p2=s,*p=NULL;
while(*p2)
{
while(*p1)
{
if(*p2>*p1) p1++;
else break;//要有出口!!!!
}
p=p1;//保存指针的位置!!!
while(*p1) p1++;
while(p1!=p)
{
*(p1+)=*p1;
p1--;
}
*(p1+)=*p1;
*p=*p2;
p2++;
p1=a;//指针复原很重要!!!!
}
puts(a);
}

八.对比

那,鉴于你有这样的毅力,明天犒劳你一个又红又脆的苹果+一盒特仑苏纯牛奶哇~

C语言每日一题之No.9的更多相关文章

  1. C语言每日一题之No.1

    鉴于在学校弱弱的接触过C,基本上很少编程,C语言基础太薄弱.刚好目前从事的是软件编程,难度可想而知.严重影响工作效率,已无法再拖下去了.为此,痛下决心恶补C语言.此前只停留在看书,光看好像也记不住,C ...

  2. C语言每日一题之No.8

    正式面对自己第二天,突然一种强烈的要放弃的冲动,在害怕什么?害怕很难赶上步伐?害怕这样坚持到底是对还是错?估计是今天那个来了,所以身体激素有变化导致情绪起伏比较大比较神经质吧(☆_☆)~矮油,女人每个 ...

  3. C语言每日一题之No.4

    这几天老大也没安排我什么项目,于是想正好趁着空补C.当然,是利用晚上加班时间,白天正常上班时间还是学习公司的平台. 今儿个突然弱弱的感觉到在公司补C是件很低级的事情,哪怕是在加班时间都会被喷,因为大家 ...

  4. C语言每日一题之No.3

    几天下来,感慨学习要坚持下来真的是件很难的事,本来说了每天一题,可是毕竟这是个细活,需要用心雕琢,有时候真的不能当天拿下来>_<.虽然说只是一题,却涉及到很多小细节,慢慢的琢磨直至完全摸透 ...

  5. C语言每日一题之No.12

    文件操作知识:如何将一个文件的内容读取到另一个文件里? fread函数和fwrite函数   1.函数功能   用来读写一个数据块. 2.一般调用形式   fread(buffer,count,siz ...

  6. C语言每日一题之No.7

    今天是正式第一天在现有的世界里与自己相处,你再也没有另一个世界可以躲避了.终于要自己面对自己了,一个人要真实的面对自己的灵魂总是痛苦的.从学校到社会的环境转换,现实与理想的冲突,个人价值观和社会价值观 ...

  7. C语言每日一题之No.6

    人总要战胜内心的懦弱的,我不能一直这么缩在里边.终究向自己发出了挑战,还是会伤心的时候,发愣的时候.如果可以,我也希望像盗梦空间的女主一直沉在两个人的梦里永远不要醒来.可是,我们谁又能抗拒时间呢?这雨 ...

  8. C语言每日一题之No.5

    总在想,但凡编程基础正常点,都不至于惨败到这个地步.也像大多数人毕业出来,新鲜的第一份工作,如果做得好还可以略有成就感,做得一般还有提升的空间,但至少不至于像我这样基本没基础的被鄙视得一塌糊涂,被外界 ...

  9. C语言每日一题之No.2

    题目:已知三个整型数8,12,6,按公式s=a+b*c计算,并显示结果 思路:定义三个整型变量a,b,c 定义一个变量s用来保存运算结果 输出 程序: #include <stdio.h> ...

随机推荐

  1. linux 解压命令大全

    .tar 解包:tar xvf FileName.tar 打包:tar cvf FileName.tar DirName (注:tar是打包,不是压缩!) --------------- .gz 解压 ...

  2. leetcode之链表排序题

    原文链接:点击打开链接 原题是这样的: Given a linked list and a value x, partition it such that all nodes less than x  ...

  3. c#部分---递归题目;猴子摘桃

    //猴子摘了好多好多桃子,一天需要吃掉总数的2/3, //觉得不过瘾,还得再多吃一个 //吃到第9天的时候,发现只有2个桃子了 //问,当初猴子摘了多少桃子 class Program { publi ...

  4. pthread_join和pthread_detach的用法(转)

    一:关于join join join是三种同步线程的方式之一.另外两种分别是互斥锁(mutex)和条件变量(condition variable). 调用pthread_join()将阻塞自己,一直到 ...

  5. 作业:用HTML制作邮箱登陆界面

    <body leftmargin="200" rightmargin="200"> <font size="45" > ...

  6. 【P1373】奶牛的卧室

    看山神的题解写出来的,sro_dydxh_orz 原题:奶牛们有一个习惯,那就是根据自己的编号选择床号.如果一头奶牛编号是a,并且有0..k-1一共k张床,那么她就会选择a  mod  k号床作为她睡 ...

  7. Qt_Window@Qt Command Prompt从命令行创建工程

    #include <QApplication> #include <QLabel> int main(int argc, char *argv[]) { QApplicatio ...

  8. js的数组操作 splice

    原文:点击打开链接 1.作用:从指定位置删除部分元素并增加新的元素                1.1.该方法返回值是被删除的元素组成的数组                1.2.splice是直接 ...

  9. jquery获取高度错误(可以获取到宽度,但获取不到高度),及解决办法

    <div class="foo"> <div style="display: none;"> 3333333 </div> ...

  10. Hive 安装配置记录

    http://yymmiinngg.iteye.com/blog/708230 export HADOOP_HOME_WARN_SUPPRESS=1 export JAVA_HOME=/home/ha ...