- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到以下问题:我需要输入直到 EOF 之前的单词以及之后的单词,以对由完全相同的字符(不一定是完全相同的字符数)组成的单词进行分组。
例如:
输入:
“abc”“acb”“abcabc”“cab”“de”“gh”“ab”“ed”“hg”“abcde”
输出:
"abc" "acb" "abcabc" "cab"
"de" "ed"
"gh" "hg"
我会记下我到目前为止所做的事情:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char **groups, word[30], **store, n = 0, k = 0;
store = malloc(1*sizeof(char *));
if (store == NULL) exit(1);
for (;;) {
printf("Enter word: ");
if (scanf("%s", word) == EOF) break;
store[n] = malloc((strlen(word)+1)*sizeof(char));
if (store[n] == NULL) exit(1);
strcpy(store[n], word);
n++;
store = realloc(store, (n+1)*sizeof(char *));
if (store == NULL) exit(1);
}
for (int i=0; i<n; i++) {
printf("%s ", store[i]);
}
return 0;
}
问题是我真的不知道如何检查字符。你能帮我一下吗?
更新
我尝试按照@jarmod的建议进行操作:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char **groups, word[30], **store, n = 0, k = 0, *aux;
store = malloc(1*sizeof(char *));
if (store == NULL) exit(1);
for (;;) {
printf("Enter word: ");
if (scanf("%s", word) == EOF) break;
store[n] = malloc((strlen(word)+1)*sizeof(char));
if (store[n] == NULL) exit(1);
strcpy(store[n], word);
n++;
store = realloc(store, (n+1)*sizeof(char *));
if (store == NULL) exit(1);
}
for (int i=0; i<n; i++) {
printf("%s ", store[i]);
}
printf("\n");
for (int i=0; i<n; i++) {
for (int j=0; j<strlen(store[i])-1; j++) {
for (int l=(j+1); l<strlen(store[i]); l++) {
if (store[i][j] > store[i][l]) {
aux = store[i][j];
store[i][j] = store[i][l];
store[i][l] = aux;
}
}
}
}
for (int i=0; i<n; i++) {
printf("%s ", store[i]);
}
printf("\n");
for (int i=0; i<n; i++) {
for (int j=0; j<strlen(store[i])-1; j++) {
if (store[i][j] == store[i][j+1]) {
for (int l=j; l<strlen(store[i])-1; l++) {
store[i][l] = store[i][l+1];
}
j--;
store[i] = realloc(store[i], (strlen(store[i])-1)*sizeof(char));
if (store[i] == NULL) exit(1);
}
}
}
for (int i=0; i<n; i++) {
printf("%s ", store[i]);
}
printf("\n");
return 0;
}
最佳答案
有一种巧妙的方法可以确定单词属于哪一组。
我们必须创建一个方案,其中每个组都由一个数字唯一标识。我们如何定义和区分一个组:通过它包含的字母。重复的字母不算数(这是一组)。因此,我们需要一个公式来对一组字母进行编码。如果我们为每个字母分配一个数字(从 0
开始),我们可以通过 2 的幂和获得 id(实际上可以选择任何基数,但 2
是计算的自然选择)。
例如:
"abdeae"
这组字母是 {'a', 'b', 'd', 'e'}
。他们对应的号码是:{0, 1, 3, 4}
ID 是 2^0 + 2^1 + 2^3 + 2^4
.
因为有26
字母我们可以使用 32 位整数来编码 id。 2^i
对应位i
所以算法看起来像这样:
uint32_t letter_mask(char ch)
{
assert(ch >= 'a' && ch <= 'z');
return (uint32_t) 1u << (ch - 'a');
}
uint32_t word_group_id(const char * str)
{
size_t len = strlen(str);
uint32_t id = 0;
for (size_t i = 0; i < len; ++i)
{
id |= letter_mask(str[i]);
}
return id;
}
<小时/>
现在我们有了一种简单的方法来确定单词组,您需要创建一个简化版本的 map 来放置单词。
这是我简单快速的实现。免责声明:未经测试。您还必须通过添加对 malloc 和 realloc 的检查来改进它。
typedef struct Word_map_bucket
{
uint32_t id;
char** words;
size_t words_size;
} Word_map_bucket;
void init_word_map_bucket(Word_map_bucket* bucket, uint32_t id)
{
bucket->id = id;
bucket->words = NULL;
bucket->words_size = 0;
}
typedef struct Word_map
{
Word_map_bucket* buckets;
size_t buckets_size;
} Word_map;
void init_word_map(Word_map* map)
{
map->buckets = NULL;
map->buckets_size = 0;
}
Word_map_bucket* find_bucket(Word_map map, uint32_t id)
{
for (size_t i = 0; i < map.buckets_size; ++i)
{
if (map.buckets[i].id == id)
return &map.buckets[i];
}
return NULL;
}
Word_map_bucket* add_new_bucket(Word_map* map, uint32_t id)
{
map->buckets = realloc(map->buckets, map->buckets_size + 1);
map->buckets_size += 1;
Word_map_bucket* bucket = &map->buckets[map->buckets_size + 1];
init_word_map_bucket(bucket, id);
return bucket;
}
void add_word(Word_map* map, const char* word)
{
// get to bucket
uint32_t id = word_group_id(word);
Word_map_bucket* bucket = find_bucket(*map, id);
if (bucket == NULL)
bucket = add_new_bucket(map, id);
// increase bucket->words
bucket->words = realloc(bucket->words, bucket->words_size + 1);
bucket->words_size += 1;
// push word into bucket
bucket->words[bucket->words_size - 1] = malloc(strlen(word));
strcpy(bucket->words[bucket->words_size - 1], word);
}
关于c - 如何检查 C 中是否由完全相同的字符组成更多单词?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54239865/
我正在开发一个带选项卡栏的 ios 应用程序。我的栏上有超过 5 个按钮,所以在 iphone 上我有更多的按钮。现在,假设我有这个按钮:Button1 Button2 Button3 Button4
我有一个带有 UITabBarController 的应用,其中有超过五个选项卡。 当我按更多选项卡时,我会转到moreNavigationController,它是一个UINavigationCon
我有一个导航 Controller 。 NAVC->MORE... 按钮,然后在“更多”下有一些额外的 VC。 如果我转到“更多...”下的 VC,然后转到不在“更多...”上的 VC,那么当我返回到
因此,我想出了这种方案,用于在多个线程同时具有读写访问权限的二叉树中旋转时锁定节点,这涉及每次旋转锁定四个节点,这似乎是一个很多吗?我想到了一种比我想出的方法更聪明的方法来减少所需的锁定,但谷歌并没有
所以我已经尝试了所有方法,但我似乎仍然无法将下拉内容与 dropbtn 对齐。我只希望内容始终位于更多菜单下方。 HTML: `
我正在尝试使用 expect 来自动接受在 --more-- 中提示的 EULA。 #!/usr/bin/expect spawn "./greenplum-perfmon-web-4.1.2.0-b
他们如何在下面提供的网站上制作“告诉我更多”效果。我读过 read more/less effect in jQuery,但我发现该站点的有趣之处在于,除非单击该按钮,否则无法滚动页面。 Effect
现在,Kim Stebel helped me understanding如何使用存在类型键入变量,我需要知道如何在继承中使用它们: 以下代码无法编译: class PagingListModel(s
在我的Cygwin中不可用。另一方面,提供了“ less”命令。也许Cygwin的制造商认为“更多”只是多余的。 我对此很好奇。 最佳答案 安装util-linux软件包,您将获得“更多”的信息 ht
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我们使用 asp.net mvc、javascript 和 jQuery(托管在本地计算机上)创建了一个应用程序。基本设计是,当用户从一个页面导航到其他页面时,我们通过隐藏和显示 HTML 页面,将所
我想用 RMonad 做一些基本的事情。有没有办法使用“as monad”功能来 有一个身份 rmonad,可以应用 monad 转换器吗? 有诸如 StateT 变压器之类的常见东西吗? 向现有 m
我有一个 char*[] 数组。我需要能够为其分配字符串并再次删除它们,但我不知道: 如何检查一个元素中是否已经有一个字符串,这样我就不会覆盖它,如果它已经被占用,则继续处理下一个元素? 之后如何将其
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我有一个程序可以同时吐出标准错误和标准输出,我想在标准错误上少运行寻呼机,但忽略标准输出。我该怎么做? 更新: 就是这样......我不想丢失标准输出......只是让它远离寻呼机 program 2
基本上,当单击具有类 "dropdown" 的链接时,我无法获取“更多...”链接来对下一个跨度的高度进行动画处理。它根本就没有动画。仅当更改为 Less... 链接并且单击 Less... 链接以折
我正在使用 ExtJS,并认为它是一个了不起的框架。但是,它们没有内置的状态图,这使得依赖于状态的应用程序开发非常痛苦。 我最近发现了这个: https://github.com/jakesgordo
我一直在研究数据结构和算法,遗憾的是在C中。我已经单独实现了一个双向链表,它保存整数并且工作正常,但是当节点(或pub)让它正常工作时我遇到了很多麻烦在本例中)保存多个不同类型的值。我可以创建一个列表
编辑拼写错误 你好, 这可能是一个愚蠢的问题,但如果它能帮助我遵循最佳实践,我不在乎:P 假设我想在 System.Data 命名空间...以及 System.Data.SqlClient 命名空间中
使用 bootstrap 3 CSS、font awesome CSS 和最新的 jQuery JS 文件。 我正在使用 javascript 在单击按钮时在另一个内容 div 之上隐藏/显示一个内容
我是一名优秀的程序员,十分优秀!