fork download
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. // binary_search関数の実装
  5. int binary_search(int a[], int n, int x) {
  6. int left = 0;
  7. int right = n - 1;
  8.  
  9. while (left <= right) {
  10. int mid = left + (right - left) / 2;
  11.  
  12. if (a[mid] == x) {
  13. return mid; // 値が見つかった場合、そのインデックスを返す
  14. }
  15. if (a[mid] < x) {
  16. left = mid + 1; // 探している値が右側にある場合
  17. } else {
  18. right = mid - 1; // 探している値が左側にある場合
  19. }
  20. }
  21. return -1; // 値が見つからない場合
  22. }
  23.  
  24. int main(void) {
  25. int n, x, i;
  26. int *a;
  27. int ans = -1;
  28.  
  29. scanf("%d %d", &n, &x);
  30. a = (int *)malloc(sizeof(int) * n);
  31. if (a == NULL) {
  32. printf("ERROR\n");
  33. return -1;
  34. }
  35. for (i = 0; i < n; i++) {
  36. scanf("%d", &a[i]);
  37. }
  38. ans = binary_search(a, n, x);
  39. if (ans != -1)
  40. printf("a[%d] = %d\n", ans, a[ans]);
  41. else
  42. printf("not found\n");
  43. free(a);
  44. return 0;
  45. }
Success #stdin #stdout 0.01s 5288KB
stdin
12 5
stdout
not found