-
-
Notifications
You must be signed in to change notification settings - Fork 184
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inconsistency in headers provided #740
Comments
When we've discussed this in the past, the goal was to use empty headers as part of the exercise. Of course, the goal is to create a learning opportunity, not put up a brick wall. I don't mentor the C track so I don't have a good feel for where people are struggling and it's entirely possible that we've missed the mark in what we provide for some of the exercises. PRs are welcome. |
I think we previously discussed if we should add Stubb's and decided only to have them for the earlier exercises. Open to discuss the idea again though. I raised the same concern on the PR and Josh validly pointed out that this policy is not apparent in the implementation. IIRC the main stumbling block that we had before was that for some exercises providing the stubs "gave the game away". With concepts starting Ng to be created perhaps this concern is less of an issue? |
I feel like I didn't include stubs where the stubs were the whole exercise... (resistor enums, etc)... but most of the time it's just the headers and then you still have to implement the actual algorithm... so I guess the question is how hard are we trying to make it... |
Having done 44 solutions myself and having mentored 200+ solutions, I can't say I recall the lack of forward declarations for some exercises to have been much of a problem for myself or others. I may have had a very few students express they had difficulty, but I don't remember any specifically. When lacking forward declarations, my own approach has been to look at the tests to see what function signature(s) they expect and take it from there. It may be a bit challenging to have to do that, but it's also rewarding when, hey! I figured it out! 😄 |
I can only say I found it a problem - perhaps it was more the inconsistency though? I was/am still a bit hazy on the difference between things like Having some/most exercises I could jump right into and then only some where I hit the no headers wall - friction and frustration. Perhaps if they all forced me to do the work it would have been better (in the long run), at least it wouldn't be inconsistent.
It can be. I just think we need to deal with the inconsistency. Seems like it shouldn't be a coin toss whether a students gets headers or not? |
I think it has to be to be inconsistent, or forward declarations would need to be made (or not made) for all exercises. For some of the very simplest exercises which are most likely to be solved by beginners, it's welcoming to provide forward declarations. Once the exercises get a bit more challenging, even the "Easy" ones, I think it starts being more appropriate to have them stretch a bit by constructing the forward declarations themselves. That wouldn't be a coin toss but a natural progression. |
We're overloading the word. It can be both. It could be consistent period (always the same) or a consistent policy across the track (as you are about to suggest:)
This sounds consistent [as a policy] but in my experience this is not how it is now.
Consistent period or consistent policy, just not randomness. :) Your proposal is reasonable. If we call can agree on policy I could revisit the PR, though it will take a bit longer since now we're adding nuance... perhaps we could do it according to difficulty numbers in the JSON? |
Outside of "Hello World", I'm not sure which exercises should definitely have forward declarations. It probably would be good for the maintainers to identify a small handful of the simplest exercises that should have them. The rest may or may not have them for whatever reason. I don't see taking them away from more difficult exercises just for the sake of consistency, but I think it's reasonable for a small subset of the easiest exercises to have them. I'm thinking five or maybe less. |
Perhaps the declarations for some exercises could be put in the Hints section. That way it wouldn't ruin it for students who want to figure them out for themselves. |
IIRC we previously completed an initiative to have stub headers for all exercises up to a certain point, with none after that point I don't recall up to which exercise exactly, but it was approximately 1/4 or 1/3 of the way through the track. I'm guessing more have crept in since then though. |
That's a reasonable compromise I think. |
Did we come to some sort of agreement here? |
Hi @siebenschlaefer
|
These are the exercises (in the order they appear on https://exercism.org/tracks/c/exercises and in config.json) with their difficulty and what the
|
Having looked at them all I agree with @joshgoebel, they are pretty inconsistent. As a C programmer I really like the exercises that provide stubs with comments. That makes it so much more obvious what I'm supposed to do, and I don't have to dig into the tests to figure that out. I'd suggest doing that for a few more exercises, especially the simpler ones or the ones at the beginning of the list. But as a mentor I see the value of having the students figure out the functions and involved types for themselves. For example for the resistor-color exercise the students have to understand enums, and I had lots of conversations about which types to use. And for several exercises I regularly have discussions about which parameters and return types should be pointers to |
Great work to get that! If the earlier exercises had stubs and the later ones required the students to figure it out I think smthis may strike a balance between getting started and learning from the tests. It's very good to hear your experience as a mentor there! |
This may possibly help to solve #807 also? |
Looks like I picked the right week to be on vacation. |
Most exercises provide at least the header to get you started (so you know what API you are implementing)... but some give you nothing. Example:
circular_buffer
... this makes it much harder to get started.Is this somehow intentional? Could we agree on what amount of boilerplate exercises should start with and then would PRs be welcome here?
The text was updated successfully, but these errors were encountered: