C语言编程,求解 输入整数n,对于有序数组a进行查找,若数组中有元素与n相同,那么输出此元素的位置

C语言编程,求解输入整数n,对于有序数组a进行查找,若数组中有元素与n相同,那么输出此元素的位置,否则将n插入到数组适当的位置,使得插入后的数组依然有序.... C语言编程,求解
输入整数n,对于有序数组a进行查找,若数组中有元素与n相同,那么输出此元素的位置,否则将n插入到数组适当的位置,使得插入后的数组依然有序.
展开
 我来答
  • 你的回答被采纳后将获得:
  • 系统奖励15(财富值+成长值)+难题奖励20(财富值+成长值)
寒寒家
2014-12-10 · TA获得超过2921个赞
知道大有可为答主
回答量:1482
采纳率:100%
帮助的人:1991万
展开全部
// 刚写的,验证过无误
#include<stdio.h>

int binary_search(int *src,int num, int tar){ //二分查找
int head = 0; 
int tail = num - 1;
int mid;
while(head <= tail){
mid = (head + tail) / 2;
if(src[mid] == tar){
return mid;
}else if(src[mid] > tar){
tail = mid - 1;
}else {
head = mid + 1;
}
if(head == tail&&src[head] != tar){
return head;
}
}
}

int insert_array(int * src,int &num, int tar){//检查并插入
int res = binary_search(src, num, tar);
if(src[res] == tar){
return res;
}else if (src[res] > tar){
for(int i = num; i > res; i--){
src[i] = src[i-1];
}
src[res] = tar;
num = num + 1;
return -1;//如果是插入操作返回-1
}else{
for(int i = num; i > res + 1; i--){
src[i] = src[i - 1];
}
src[res + 1] = tar;
num = num + 1;
return -1;//
}
}
int main(){
int src[10] = {1, 2 ,4, 8};
int num = 4;
int res = insert_array(src, num, 9);
printf("%d\n", res);
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
宇宙千雪
2014-12-10
知道答主
回答量:1
采纳率:0%
帮助的人:2.2万
展开全部
我给你给个思路:对于有序的数组可以采用二分查找比较快,要实现起来也很容易。要是没找着,就插入。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
furious_tauren
2014-12-10 · TA获得超过4056个赞
知道大有可为答主
回答量:1913
采纳率:100%
帮助的人:773万
展开全部
#include <stdio.h>
#define N 10

int main(void)
{
    int a[N] = { 1, 2, 5, 7, 9 };
    int i = N - 1, n;

    scanf("%d", &n);

    while (a[i] == 0)
        i--;

    while (a[i] > n) {
        a[i + 1] = a[i];
        i--;
    }
    
    if (a[i] == n)
        printf("already exist(%d)\n", i + 1);
    else
        a[i + 1] = n;

    return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式