25

Pythonのように、値またはオブジェクトが配列に存在するかどうかを確認する方法を知りたいです。

a = [1,2,3,4,5]
b = 4
if b in a:
    print("True!")
else:
    print("False")

似たようなものがすでにcythonに存在するかどうか知りたいです。ポインタの構造体オブジェクト配列があります。オブジェクトがこの配列に存在するかどうかを知りたいです。

好き

cdef Node *array

array = <Node *>malloc( 5 * cython.sizeof(Node))

for i in range(5):
     array[i].index = i

cdef Node test = array[3]

if test in array:
    print("True!")

cdef struct Node:
    int index

上記のコードは正しくありませんが、それは私が何を意味するかを示しています。

4

2 に答える 2

35

配列を繰り返し処理して、各要素を確認する必要があります。

#include <stdbool.h>

bool isvalueinarray(int val, int *arr, int size){
    int i;
    for (i=0; i < size; i++) {
        if (arr[i] == val)
            return true;
    }
    return false;
}
于 2013-02-27T00:23:23.813 に答える
-3

次に試してください:

(コメントとテストを読んで、それがどのように機能するかを詳細に確認してください)

#include <stdio.h>
#include <assert.h>


/*
Return index an integer number begin from start an array,
otherwise return -1.
 */
int indexOf(int *array, int array_size, int number) {
    for (int i = 0; i < array_size; ++i) {
        if (array[i] == number) {
            return i;
        }
    }
    return -1;
}


// Tests for indexOf()
void test_indexOf() {
    int array[10] = {12, 78, -43, 0, 21, 12, 20, -9, 1, -1};
    assert(indexOf(array, 10, 12) == 0);
    assert(indexOf(array, 10, 0) == 3);
    assert(indexOf(array, 10, 2) == -1);
    assert(indexOf(array, 10, 43) == -1);
    assert(indexOf(array, 10, 11) == -1);
    assert(indexOf(array, 10, -1) == 9);
    assert(indexOf(array, 10, 1) == 8);
    assert(indexOf(array, 10, -2) == -1);
    assert(indexOf(array, 10, 3) == -1);
}


int main () {
    test_indexOf();
    return 0;
}

ノート:

  1. Cはリロード関数をサポートしていないため、indexOf()は整数の配列型でのみ機能します。

  2. Cは、配列のポインターの長さを決定することをサポートしていません。したがって、配列のサイズを手動で渡す必要があります。

  3. テスト環境:

-

$ uname -a
Linux wlysenko-Aspire 3.13.0-37-generic #64-Ubuntu SMP Mon Sep 22 21:28:38 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux
$ gcc --version
gcc (Ubuntu 4.8.5-2ubuntu1~14.04.1) 4.8.5
于 2016-12-10T12:06:56.143 に答える