求解C语言题目

 我来答
飘零的狐狸
2019-06-11 · TA获得超过1.8万个赞
知道大有可为答主
回答量:9251
采纳率:77%
帮助的人:2261万
展开全部
先占位置 烦请采纳 先回答第一题
对排好序的数组 二分法查找
#include "stdafx.h"
#include <stdio.h>
int BinSearch(int A[],int x,int n)//A为排好序的数组,x为需要查找的数,n为
{
int a,b,i;//定义a,b记录下标
a=0;
b=n;
do
{
if(a+1==b) return 0;//找不到的时候返回0
i=a+(b-a)/2;//找到中间下标
if(A[i]>x) b=i; //根据大小更改下标
else if(A[i]<x) a=i;
}while(A[i]!=x) ;
return i+1;
}
int main()
{
int A[100],n,x,i;
scanf("%d",&n);//输入数组个数
for(i=0;i<n;i++)
{
scanf("%d",&A[i]);//输入数组元素 排好序的
}
scanf("%d",&x);//输入查询的元素
i=BinSearch(A,x,n-1);
if(i)
printf("%d在第%d个位置\n",x,i);
else printf("%d没找到\n");
return 0;
}
第二题
#include "stdafx.h"
#include <stdio.h>
#include <string.h>
int fun(char *a,char *b)
{
while(*a!='\0'&&*b!='\0')
{
if(*a==*b)
{
a++;
b++;
}
else return 0;
}
if(*a!='\0'||*b!='\0') return 0;
return 1;
}
int main()
{
char m[100],n[100];
scanf("%s",&m);
scanf("%s",&n);
if(fun(m,n)) printf("两个字符数组相等\n");
else printf("两个字符数组不相等\n");
return 0;
}
更多追问追答
追答

钺森莉SW
2019-06-14 · TA获得超过197个赞
知道小有建树答主
回答量:402
采纳率:58%
帮助的人:67.2万
展开全部
将b%2=0改为b%2==0
将b%2=1改为b%2==1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式