Repair warning: ISO C + + forbids converting a string constant to 'char *' [- wwrite strings] (#683)

* Add header file

* Add header file and regulate code style

* Add header file and regulate code style

*  Do not use namespace using-directives.  Use using-declarations instead.

* Arctic2333 Add header file and regulate code style . Do not use namespace using-directives. Use using-declarations instead.

* Repair warning: ISO C + + forbids converting a string constant to 'char *' [- wwrite strings]

* Repair warning: ISO C + + forbids converting a string constant to 'char *' [- wwrite strings]

* rename

* RENAME

* Repair warning: ISO C + + forbids converting a string constant to 'char *' [- wwrite strings]

* char * -> string

* Update and rename trietree.cpp to trie_tree.cpp

* Delete TrieTree.cpp

* char hello[] = "hello";
This commit is contained in:
苏淞丰
2019-12-19 17:37:30 +08:00
committed by Christian Clauss
parent 6e9f64db6a
commit 78f500e864
2 changed files with 91 additions and 97 deletions

View File

@@ -1,97 +0,0 @@
#include <iostream>
#include <string.h>
#include <stdbool.h>
using namespace std;
// structure definition
typedef struct trie
{
struct trie *arr[26];
bool isEndofWord;
} trie;
// create a new node for trie
trie *createNode()
{
trie *nn = new trie();
for (int i = 0; i < 26; i++)
nn->arr[i] = NULL;
nn->isEndofWord = false;
return nn;
}
// insert string into the trie
void insert(trie *root, char *str)
{
for (int i = 0; i < strlen(str); i++)
{
int j = str[i] - 'a';
if (root->arr[j])
{
root = root->arr[j];
}
else
{
root->arr[j] = createNode();
root = root->arr[j];
}
}
root->isEndofWord = true;
}
// search a string exists inside the trie
bool search(trie *root, char *str, int index)
{
if (index == strlen(str))
{
if (!root->isEndofWord)
return false;
return true;
}
int j = str[index] - 'a';
if (!root->arr[j])
return false;
return search(root->arr[j], str, index + 1);
}
/* removes the string if it is not a prefix of any other
string, if it is then just sets the endofword to false, else
removes the given string*/
bool deleteString(trie *root, char *str, int index)
{
if (index == strlen(str))
{
if (!root->isEndofWord)
return false;
root->isEndofWord = false;
for (int i = 0; i < 26; i++)
return false;
return true;
}
int j = str[index] - 'a';
if (!root->arr[j])
return false;
bool var = deleteString(root, str, index + 1);
if (var)
{
root->arr[j] = NULL;
if (root->isEndofWord)
return false;
else
{
int i;
for (i = 0; i < 26; i++)
if (root->arr[i])
return false;
return true;
}
}
}
int main()
{
trie *root = createNode();
insert(root, "hello");
insert(root, "world");
int a = search(root, "hello", 0);
int b = search(root, "word", 0);
printf("%d %d ", a, b);
return 0;
}

View File

@@ -0,0 +1,91 @@
#include <stdio.h>
#include <string.h>
#include <stdbool.h>
#include <iostream>
// structure definition
typedef struct trie {
struct trie * arr[26];
bool isEndofWord;
}
trie;
// create a new node for trie
trie * createNode() {
trie * nn = new trie();
for (int i = 0; i < 26; i++)
nn -> arr[i] = NULL;
nn -> isEndofWord = false;
return nn;
}
// insert string into the trie
void insert(trie * root, char * str) {
for (int i = 0; i < strlen(str); i++) {
int j = str[i] - 'a';
if (root -> arr[j]) {
root = root -> arr[j];
} else {
root -> arr[j] = createNode();
root = root -> arr[j];
}
}
root -> isEndofWord = true;
}
// search a string exists inside the trie
bool search(trie * root, char * str, int index) {
if (index == strlen(str)) {
if (!root -> isEndofWord)
return false;
return true;
}
int j = str[index] - 'a';
if (!root -> arr[j])
return false;
return search(root -> arr[j], str, index + 1);
}
/* removes the string if it is not a prefix of any other
string, if it is then just sets the endofword to false, else
removes the given string*/
bool deleteString(trie * root, char * str, int index) {
if (index == strlen(str)) {
if (!root -> isEndofWord)
return false;
root -> isEndofWord = false;
for (int i = 0; i < 26; i++)
return false;
return true;
}
int j = str[index] - 'a';
if (!root -> arr[j])
return false;
bool
var = deleteString(root, str, index + 1);
if (var) {
root -> arr[j] = NULL;
if (root -> isEndofWord) {
return false;
} else {
int i;
for (i = 0; i < 26; i++)
if (root -> arr[i])
return false;
return true;
}
}
}
int main() {
trie * root = createNode();
char hello[] = "hello";
char world[] = "world";
char word[] = "word";
insert(root, hello);
insert(root, world);
int a = search(root, hello, 0);
int b = search(root, word, 0);
printf("%d %d ", a, b);
return 0;
}