fork download
  1. //第3回 課題1
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4.  
  5. //この関数を実装する
  6. int binary_search(int a[],int n,int x){
  7. //この関数の内側だけを書く
  8. int ret=-1;//見つからなかったときは-1のまま。
  9. int i,lef=0,mid,rig=n-1;
  10. while(lef<=rig)//左側の文字のほうが大きいという前提条件が成り立つ間のみ
  11. {
  12. mid=(lef+rig)/2;
  13. if(a[mid]==x)ret=mid;
  14. break;
  15. }
  16. if(x<a[mid])rig=mid-1;
  17. else lef=mid+1;
  18.  
  19. return ret;
  20. }
  21.  
  22.  
  23.  
  24. int main(void) {
  25. int n,x,i;
  26. int *a;
  27. int ans = -1;
  28. scanf("%d %d",&n,&x);
  29. a = (int*)malloc(sizeof(int)*n);
  30. if(a==NULL){
  31. printf("ERROR\n");
  32. return -1;
  33. }
  34. for(i=0;i<n;i++){
  35. scanf("%d",&a[i]);
  36. }
  37. ans = binary_search(a,n,x);
  38. if(ans != -1) printf("a[%d] = %d\n",ans,a[ans]);
  39. else printf("not found\n");
  40. free(a);
  41. return 0;
  42. }
  43.  
Success #stdin #stdout 0.01s 5300KB
stdin
12 5
4 2 17 11 8 13 3 5 18 12 10 1
stdout
not found