c++ - 从输入到输出的哈希表
问题描述
我想实现哈希表,到目前为止,当我想将第一个字符串写入 Tabh 时,我已经从文件中读取并且某些内容不起作用。代码编译没有错误,但控制台中没有出现任何内容。有人可以帮我吗?我认为我错误地实现了: if (Tabp[ite].substr(0) == "a"){...}
#include <iostream>
#include <fstream>
using namespace std;
void Add(string T[], int r, long k, string w);
//void print();
//void delete();
//void stop();
int main()
{
string linie;
int licznik = 0;
ifstream policz("test.txt");
while(getline(policz, linie))
licznik++;
policz.close();
string * Tabp = new string[licznik];
fstream plik;
plik.open("test.txt");
string wiersz;
for (int b =0; b<licznik; b++)
{
getline(plik, wiersz);
Tabp[b] = wiersz;
}
string iloscprzypadkow = Tabp[0].substr(0);
int n = stoi(iloscprzypadkow);
string rozmiarstring = Tabp[1].substr(5,7);
int size = stoi(rozmiarstring);
string * Tabh = new string[size];
for (int ite=2; ite<licznik; ite++)
if (Tabp[ite].substr(0) == "a")
{
string temp = Tabp[ite].substr(4,5);
long klucz = stoi(temp);
string wartosc = Tabp[ite].substr(7,14);
Add(Tabh, size, klucz, wartosc);
}
//if (wyrazenie == "p")
//{
//}
//if (wyrazenie == "d")
//}
//{
//if (wyrazenie == "s")
//{
//}
}
void Add(string Tabh[], int rozmiar, long klucz, string wartosc)
{
cout<<rozmiar<<klucz<<wartosc;
int indeks = klucz%rozmiar;
Tabh[indeks] = wartosc;
cout<<indeks<<" "<<klucz<<" "<<wartosc;
}
-------------------------
input:
1
size 10
add 13 ala
print
add 23 ola
print
delete 13
print
stop
解决方案
的一个参数版本substr
返回从给定索引开始到字符串末尾的子字符串。因此,您的调用Tabp[ite].substr(0)
将返回Tabp[ite]
. 要获取一个字符的子字符串,您需要指定使用两个参数版本,其中第二个参数是您想要的子字符串的长度(不是结束索引,因为它看起来您正在代码的其他地方执行)。
So you'd want to use Tabp[ite].substr(0,1) == "A"
. Or, since it is just one character, just check that single character with Tabp[ite][0] == 'A'
.
推荐阅读
- xslt-1.0 - 如何额外两个日期属性来构建一个新的文本字符串
- google-app-engine - App Engine - 是否必须使用预热请求才能使用 min_instances?
- xml - 为密钥设置 xsd 并验证 xml
- node.js - 同步/异步功能和冻结的后台循环
- elasticsearch - Elastic Search - Count api 显示不正确的索引文档总数
- javascript - 从捆绑在一起的 JS 模块中指向公共依赖项的最佳方法是什么?
- leaflet - 在传单中放大和显示/隐藏标签
- vba - 如果没有回复,如何发送后续电子邮件?
- java - Hibernate JPA 映射相同类型的多个实体
- ruby - bsearch_index 的奇怪行为