• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EST 23:31
CET 05:31
KST 13:31
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
RSL Season 3 - Playoffs Preview0RSL Season 3 - RO16 Groups C & D Preview0RSL Season 3 - RO16 Groups A & B Preview2TL.net Map Contest #21: Winners12Intel X Team Liquid Seoul event: Showmatches and Meet the Pros10
Community News
Weekly Cups (Nov 24-30): MaxPax, Clem, herO win2BGE Stara Zagora 2026 announced15[BSL21] Ro.16 Group Stage (C->B->A->D)4Weekly Cups (Nov 17-23): Solar, MaxPax, Clem win3RSL Season 3: RO16 results & RO8 bracket13
StarCraft 2
General
BGE Stara Zagora 2026 announced Weekly Cups (Nov 24-30): MaxPax, Clem, herO win SC2 Proleague Discontinued; SKT, KT, SGK, CJ disband Information Request Regarding Chinese Ladder SC: Evo Complete - Ranked Ladder OPEN ALPHA
Tourneys
$5,000+ WardiTV 2025 Championship Constellation Cup - Main Event - Stellar Fest RSL Revival: Season 3 Tenacious Turtle Tussle [Alpha Pro Series] Nice vs Cure
Strategy
Custom Maps
Map Editor closed ?
External Content
Mutation # 502 Negative Reinforcement Mutation # 501 Price of Progress Mutation # 500 Fright night Mutation # 499 Chilling Adaptation
Brood War
General
Which season is the best in ASL? [ASL20] Ask the mapmakers — Drop your questions BW General Discussion FlaSh's Valkyrie Copium BGH Auto Balance -> http://bghmmr.eu/
Tourneys
[Megathread] Daily Proleagues [BSL21] RO16 Group B - Sunday 21:00 CET [BSL21] RO16 Group C - Saturday 21:00 CET Small VOD Thread 2.0
Strategy
Game Theory for Starcraft How to stay on top of macro? Current Meta PvZ map balance
Other Games
General Games
Stormgate/Frost Giant Megathread The Perfect Game Path of Exile Nintendo Switch Thread Should offensive tower rushing be viable in RTS games?
Dota 2
Official 'what is Dota anymore' discussion
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug Heroes of StarCraft mini-set
TL Mafia
Mafia Game Mode Feedback/Ideas TL Mafia Community Thread
Community
General
Things Aren’t Peaceful in Palestine Russo-Ukrainian War Thread US Politics Mega-thread The Big Programming Thread Artificial Intelligence Thread
Fan Clubs
White-Ra Fan Club
Media & Entertainment
[Manga] One Piece Movie Discussion! Anime Discussion Thread
Sports
2024 - 2026 Football Thread Formula 1 Discussion NBA General Discussion
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
Where to ask questions and add stream? The Automated Ban List
Blogs
James Bond movies ranking - pa…
Topin
Esports Earnings: Bigger Pri…
TrAiDoS
Thanks for the RSL
Hildegard
Saturation point
Uldridge
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1408 users

The Big Programming Thread - Page 391

Forum Index > General Forum
Post a Reply
Prev 1 389 390 391 392 393 1032 Next
Thread Rules
1. This is not a "do my homework for me" thread. If you have specific questions, ask, but don't post an assignment or homework problem and expect an exact solution.
2. No recruiting for your cockamamie projects (you won't replace facebook with 3 dudes you found on the internet and $20)
3. If you can't articulate why a language is bad, don't start slinging shit about it. Just remember that nothing is worse than making CSS IE6 compatible.
4. Use [code] tags to format code blocks.
mcc
Profile Joined October 2010
Czech Republic4646 Posts
November 12 2013 04:41 GMT
#7801
On November 12 2013 01:52 Yoshi- wrote:
Show nested quote +
On November 11 2013 07:30 sluggaslamoo wrote:

If you have any functions that are longer than 10 lines seriously have a look at them and see if you can't break them down. Most of my functions are 1-3 (ruby) lines long, this is due to functional programming though, I'd say for PHP they should float between 3 to 5 lines on average.


Yea that is bullshit
I all up for splitting code into smaller part, but saying that you should average between 3 to 5 lines is just ridiculous

Yeah, that seems like the strangest advice ever. If you have most of your functions 1-5 lines long and are working on actual project, not some proof-of-concept code, you are most likely writing bloated and unreadable code, where the actual logic is hiding behind unnecessary numbers of artificial functions.
mcc
Profile Joined October 2010
Czech Republic4646 Posts
November 12 2013 04:44 GMT
#7802
On November 12 2013 07:16 Frigo wrote:
Show nested quote +
On November 12 2013 02:37 Manit0u wrote:
And remember, extends are evil. Interface inheritance > implementation inheritance.

components > delegation > mixins > interfaces > inheritance

As wrong and simplifying as the original post. The original might be a nice rough guideline, but that is it. There are instances where the order is completely reversed. And they are not exceptions. I am not even sure they are necessarily majority due to complexities of all possible orderings.
Rollin
Profile Joined March 2011
Australia1552 Posts
November 12 2013 05:49 GMT
#7803
On November 12 2013 11:54 phar wrote:
Show nested quote +
On November 12 2013 11:41 Cyx. wrote:
On November 12 2013 11:27 phar wrote:
Oh wait nevermind you're this guy:

On April 30 2013 10:57 sluggaslamoo wrote:
As a whole, I'd say 95% of all developers in the world are absolutely atrocious because of the reason you gave. A very tiny fraction of developers actually know how to write good code and engage in computer science. I do not work with those kinds of developers and neither do my workmates because they are simply a waste of time.

I don't know why this is my loss, I get paid a substantially higher amount compared to your developers and get to work in a really good environment because of said reasons. Developers like yours would not even pass the interview of some of the companies I've worked in.


So did like three whole days of posts get burned out of this thread, or is that from somewhere else? Because I went looking for context on that quote and there is nothing for the day before that date to the day after that date in this thread... and now I feel like I missed a good flame war

Sorry, unrelated thread from awhile back. http://www.teamliquid.net/forum/viewmessage.php?topic_id=410026&currentpage=18#341

I like his very last post though, it's very hard to fault and rings very true in my ears.

http://www.teamliquid.net/forum/viewmessage.php?topic_id=410026&currentpage=22#421
Throw off those chains of reason, and your prison disappears. | Check your posting frequency timeline: http://www.teamliquid.net/mytlnet/post_activity_img.php
phar
Profile Joined August 2011
United States1080 Posts
November 12 2013 06:00 GMT
#7804
Yes I agree with many of his arguments. I'm just against his holier-than-thou and dismissive delivery. What drove the nail into the coffin for me was calling my co-workers inferior and lower paid, without knowing where I work or how much I make. That shows an astounding level of arrogance.
Who after all is today speaking about the destruction of the Armenians?
Abductedonut
Profile Blog Joined December 2010
United States324 Posts
Last Edited: 2013-11-12 06:56:42
November 12 2013 06:50 GMT
#7805
On November 12 2013 13:41 mcc wrote:

Yea that is bullshit
I all up for splitting code into smaller part, but saying that you should average between 3 to 5 lines is just ridiculous
Yeah, that seems like the strangest advice ever. If you have most of your functions 1-5 lines long and are working on actual project, not some proof-of-concept code, you are most likely writing bloated and unreadable code, where the actual logic is hiding behind unnecessary numbers of artificial functions.


It's not bullshit, and it's not strange advice. Sluggaslamoo idea's are coming from a book called Clean Code by Robert C. Martin. I'll let you Google him to figure out whether or not you should follow his advice.

In his book, he mentions some things about functions:

- Functions should be tiny.
- Functions should do one thing
- One Level of Abstraction per Function
- The Stepdown Rule

Functions should be tiny because it actually makes code a lot easier to debug, follow, and read. If your "actual logic is hiding behind an unnecessary number of artificial functions" then you're not doing it right. This is tightly coupled with the idea that there should be one level of abstraction per function. For example - consider this code:


void ExecuteCommand(char *command)
{
ParseCommand(command);
ValidateCommand(command);
CreateCommandTree(command);

for( int i = 0; i < strlen(command); i++)
command[i]++;
}

void ParseCommand(char* command)
{}

void ValidateCommand(char* command)
{}

void CreateCommandTree(char* command)
{}


Isn't the for loop in the ExecuteCommand function a little odd? That's what one level of abstraction per function means. ExecuteCommand is a high-level function - we shouldn't do char-by-char string manipulation in it because it breaks the flow of the code. The step-down rule says that i shouldn't have to hunt around the code to find functions that I need. ParseCommand should immediately follow ExecuteCommand... etc etc. That way, code reads like a "book." You can see that structure in the way functions are defined in my code above.

These are just some of his ideas. Now - there are some extremely successful pieces of software that don't do these things. I'm looking at fork.c in the linux kernel code and there's a function that's 60+ lines long. It's also ugly as hell, and I can't immediately see what it's doing, whereas my code - simple as it may be - is somewhat obvious. "Well first he's parsing the command... then validating it... then creating some sort of 'command tree'."

There's a reason Sluggaslamoo is saying what he's saying. He's not talking out of his ass. The fact that you didn't know he was talking about Clean Code shows that you aren't as read up on the literature of writing code as well as you should be. Pragmatic Programmer and Clean Code should be part of any programmer's arsenal - if only to broaden your horizons.

As for what he posted in the other thread, I wholeheartedly agree. The best programmers do dedicate their lives to mastering the art. In fact, in his book Outliers, Malcolm Gladwell talks about how it takes at least 10,000 hours of doing something to truly master it. You may believe that Bill Gates got lucky in making his fortune, but the truth is that he spent thousands of hours programming (which he talks about in his book).
SimoneElektra
Profile Joined November 2013
Korea (South)7 Posts
November 12 2013 06:55 GMT
#7806
It's no so big after all
believe and it shall happen
spinesheath
Profile Blog Joined June 2009
Germany8679 Posts
Last Edited: 2013-11-12 08:28:03
November 12 2013 08:27 GMT
#7807
On November 12 2013 15:50 Abductedonut wrote:
It's not bullshit, and it's not strange advice. Sluggaslamoo idea's are coming from a book called Clean Code by Robert C. Martin. I'll let you Google him to figure out whether or not you should follow his advice.

In his book, he mentions some things about functions:

- Functions should be tiny.
- Functions should do one thing
- One Level of Abstraction per Function
- The Stepdown Rule

I just (re-) read that chapter of the book.

Here's the thing: These guidelines you mention are good. And sluggaslamoo's first statement on the issue wasn't bad either as he merely suggested to have a look at larger functions and see if they can't be refactored.

However then it spiraled out of control and people started talking in absolutes. Absolutes are always wrong.

The rule is not "your functions should be 3-5 lines or else you're stupid". It's "try to keep things as simple as you can".

Have a look at your largest functions, see if you can split them up meaningfully and with adequate effort. If you can't, don't. Occasionally come back and have a look at them again.

For example, I've written functions that check for ~20 nontrivial rules. Even if I split it up into 20 seperate functions, I still have one function with 20 lines calling each of the rule checks (and zero code reuse anyways). The proper way of refactoring it would be to develop a way to specify these rules in an XML file and write code to load these rules and apply them in a loop.
That's a ton of work, hardly worth the gain as these rules are never going to change.
If you have a good reason to disagree with the above, please tell me. Thank you.
obesechicken13
Profile Blog Joined July 2008
United States10467 Posts
Last Edited: 2013-11-12 14:17:55
November 12 2013 14:14 GMT
#7808
The idea of having a function do one thing is nice. Especially for large projects.

What's the rule for files of code? eg. module1.py module2.py (replace py for any other language)

One file for one module seems nice but then you realize that the server has many sub-modules. I can't think of any rules for which submodules to use.


While we're talking about simplicity, I find that it's impossible to scale up large projects until I work in an IDE like eclipse that lets me see the header comments of a function by hovering over it, and by navigating to an implementation using ctrl+click. I tried creating a project in python without an IDE because Pyscripter and pycharms and idlex were buggy, but then it was impossible to keep track of everything.

The best practices are useless if you don't have the development environment to use them sine they just make the job a lot harder.
For example, I don't think vim offers code navigation. At least not out of the box.

If your company doesn't suggest that most people use an IDE with code navigation, then many people may not use one and you end up with this kind of code. I find using an IDE has made my functions 10x smaller and much more readable.

fuck: late for class! Sorry if something wasn't clear.
I think in our modern age technology has evolved to become more addictive. The things that don't give us pleasure aren't used as much. Work was never meant to be fun, but doing it makes us happier in the long run.
mcc
Profile Joined October 2010
Czech Republic4646 Posts
November 12 2013 14:15 GMT
#7809
On November 12 2013 15:50 Abductedonut wrote:
Show nested quote +
On November 12 2013 13:41 mcc wrote:

Yea that is bullshit
I all up for splitting code into smaller part, but saying that you should average between 3 to 5 lines is just ridiculous
Yeah, that seems like the strangest advice ever. If you have most of your functions 1-5 lines long and are working on actual project, not some proof-of-concept code, you are most likely writing bloated and unreadable code, where the actual logic is hiding behind unnecessary numbers of artificial functions.


It's not bullshit, and it's not strange advice. Sluggaslamoo idea's are coming from a book called Clean Code by Robert C. Martin. I'll let you Google him to figure out whether or not you should follow his advice.

In his book, he mentions some things about functions:

- Functions should be tiny.
- Functions should do one thing
- One Level of Abstraction per Function
- The Stepdown Rule

Functions should be tiny because it actually makes code a lot easier to debug, follow, and read. If your "actual logic is hiding behind an unnecessary number of artificial functions" then you're not doing it right. This is tightly coupled with the idea that there should be one level of abstraction per function. For example - consider this code:


void ExecuteCommand(char *command)
{
ParseCommand(command);
ValidateCommand(command);
CreateCommandTree(command);

for( int i = 0; i < strlen(command); i++)
command[i]++;
}

void ParseCommand(char* command)
{}

void ValidateCommand(char* command)
{}

void CreateCommandTree(char* command)
{}


Isn't the for loop in the ExecuteCommand function a little odd? That's what one level of abstraction per function means. ExecuteCommand is a high-level function - we shouldn't do char-by-char string manipulation in it because it breaks the flow of the code. The step-down rule says that i shouldn't have to hunt around the code to find functions that I need. ParseCommand should immediately follow ExecuteCommand... etc etc. That way, code reads like a "book." You can see that structure in the way functions are defined in my code above.

These are just some of his ideas. Now - there are some extremely successful pieces of software that don't do these things. I'm looking at fork.c in the linux kernel code and there's a function that's 60+ lines long. It's also ugly as hell, and I can't immediately see what it's doing, whereas my code - simple as it may be - is somewhat obvious. "Well first he's parsing the command... then validating it... then creating some sort of 'command tree'."

There's a reason Sluggaslamoo is saying what he's saying. He's not talking out of his ass. The fact that you didn't know he was talking about Clean Code shows that you aren't as read up on the literature of writing code as well as you should be. Pragmatic Programmer and Clean Code should be part of any programmer's arsenal - if only to broaden your horizons.

As for what he posted in the other thread, I wholeheartedly agree. The best programmers do dedicate their lives to mastering the art. In fact, in his book Outliers, Malcolm Gladwell talks about how it takes at least 10,000 hours of doing something to truly master it. You may believe that Bill Gates got lucky in making his fortune, but the truth is that he spent thousands of hours programming (which he talks about in his book).

Why should I read the book, when everything you said is obvious and I knew that already without ever reading that book ? If you think enough about what you are doing when programming, you will come up with those guidelines yourself. Of course reading that book might save you time or point you in the correct direction faster, but they are not required. The fact that you think that those ideas are unavailable to anyone who did not read the book is rather telling. And all those guidelines are actually complex. You need to actually understand them, when they apply, when to ignore them,.... All those guidelines are tradeoffs. No non-trivial programming guideline is without tradeoff. The guideline about minimizing function length and complexity runs against multiple other guidelines that have their own strong rationale. Your job as a programmer is not to know and use those guidelines, but knowing when they are applicable and when to ignore them and how to balance the conflicting ones in current context.

I am not disagreeing with the general ideas. I am disagreeing with the specific metric of "small". I encountered too many functions that were longer than 5-10 lines and any further decomposition would make the code less readable. You end up with artificially named functions that are reusable only rarely and barely. Also this rule depends heavily on the language used.
I am also disagreeing with blanket absolute guidelines. Programming guidelines require understanding of context and applicability and I suspect none of those guidelines can be transferred to a person without enough programming experience. I would actually say that reading book explaining them is helpful only if you are already on the cusp of discovering them yourself, but that is just my hypothesis. Basically the whole thing is more complex than simple guidelines that are always applicable.

Just to point it out on the specific example. The minimizing function complexity guideline runs against "locality", which is one of the most important guidelines of team programming. Code implementing a use-case should be as concentrated as possible so anyone changing that code, no matter how uninformed and bad will have all the information necessary for that change right in his face thus making errors less likely. It also runs a risk of merging execution sequences that never should have been merged, because again those merged execution sequences make it more likely for a programmer implementing change request to only take into account one of the merged use-cases, but changing unintentionally both. It also goes against readability in many instances. Different people have different notions of readability, but multiplying function beyond necessity decreases readability for most people. And of course those rules I mentioned have to be balanced against multiple other rules and so on. It is all about balancing conflicting requirements. Simple solutions are always false promises.
Tobberoth
Profile Joined August 2010
Sweden6375 Posts
Last Edited: 2013-11-12 16:05:10
November 12 2013 16:05 GMT
#7810
On November 12 2013 23:15 mcc wrote:
You end up with artificially named functions that are reusable only rarely and barely.

Well, the point in this case isn't reusability, it's readability. It doesn't matter if a function is used only once if it makes program flow more readable. You're right that it's not always a good idea to split up a function just because it has more than 5 lines of code, but I definitely don't think one should shy away from refactoring logic into smaller functions just because you see no reason to use said function anywhere else. I would say, anywhere you need comments to make it immediately clear what a bunch of code is doing, it might be a better idea to remove the comment and make it into a function with a fitting name instead.
mcc
Profile Joined October 2010
Czech Republic4646 Posts
Last Edited: 2013-11-12 16:30:00
November 12 2013 16:25 GMT
#7811
On November 13 2013 01:05 Tobberoth wrote:
Show nested quote +
On November 12 2013 23:15 mcc wrote:
You end up with artificially named functions that are reusable only rarely and barely.

Well, the point in this case isn't reusability, it's readability. It doesn't matter if a function is used only once if it makes program flow more readable. You're right that it's not always a good idea to split up a function just because it has more than 5 lines of code, but I definitely don't think one should shy away from refactoring logic into smaller functions just because you see no reason to use said function anywhere else. I would say, anywhere you need comments to make it immediately clear what a bunch of code is doing, it might be a better idea to remove the comment and make it into a function with a fitting name instead.

I am not saying you should shy away from considering it. I am saying there are multiple other things to consider and you should understand that nearly always it is a tradeoff with some other potentially valuable property. You might decide that those properties are not as important in your current situation. But absolute statements that they are never important is what I am arguing against.

Sometime you need comments because the algorithm is not clear due to for example speed concerns. You could argue that it should go into documentation and not a comment. But such comment is not an indication that you can move it to some other function, quite often it is sign that you should absolutely not do that or that it is impractical.

EDIT: Plus my main argument in part you quoted was also readability, reusability was only sidenote to underscore how useless it is sometimes to decompose functions as you gain neither. But big number of artificial functions that do not do anything that can be described in reasonable name and were created purely because it was possible to split original function can also affect readability negatively. And frankly in more than few occasions those decompositions are nothing more than exactly that. In some languages 1-3 lines is enough to express some non-trivial constructs. In some it is basically impossible.
pedrlz
Profile Joined September 2012
Brazil5234 Posts
November 12 2013 16:40 GMT
#7812
I'm learning Clojure since the only lang I knew before was Lisp (just a little), but it is hard for me to practice.

But there isn't a lot of exercises available and all I try to do seems too complex for what I can do.

What todo, should I just read books? It is a little boring, looks like that I'm not learning a lot and I forget easily. I started to get codes from the internet and trying to break down to understand what is happening, isn't the fastest way neither the easiest, but is a little more action

Also, I'm learning just for fun, that is way I'm trying Clojure (syntax from non-lisp scares me)
freelander
Profile Blog Joined December 2004
Hungary4707 Posts
November 12 2013 16:54 GMT
#7813
On November 13 2013 01:40 pedrlz wrote:
I'm learning Clojure since the only lang I knew before was Lisp (just a little), but it is hard for me to practice.

But there isn't a lot of exercises available and all I try to do seems too complex for what I can do.

What todo, should I just read books? It is a little boring, looks like that I'm not learning a lot and I forget easily. I started to get codes from the internet and trying to break down to understand what is happening, isn't the fastest way neither the easiest, but is a little more action

Also, I'm learning just for fun, that is way I'm trying Clojure (syntax from non-lisp scares me)


that's quite a unique way to get started lol
And all is illuminated.
pedrlz
Profile Joined September 2012
Brazil5234 Posts
Last Edited: 2013-11-12 16:56:15
November 12 2013 16:55 GMT
#7814
On November 13 2013 01:54 freelander wrote:
Show nested quote +
On November 13 2013 01:40 pedrlz wrote:
I'm learning Clojure since the only lang I knew before was Lisp (just a little), but it is hard for me to practice.

But there isn't a lot of exercises available and all I try to do seems too complex for what I can do.

What todo, should I just read books? It is a little boring, looks like that I'm not learning a lot and I forget easily. I started to get codes from the internet and trying to break down to understand what is happening, isn't the fastest way neither the easiest, but is a little more action

Also, I'm learning just for fun, that is way I'm trying Clojure (syntax from non-lisp scares me)


that's quite a unique way to get started lol

Well, I started with Lisp but then I learned about Clojure that can use Java Libraries and I thought that could be easier/more useful.

But I'm just shooting in the dark
welp
RoyGBiv_13
Profile Blog Joined August 2010
United States1275 Posts
November 12 2013 19:23 GMT
#7815
On November 13 2013 01:55 pedrlz wrote:
Show nested quote +
On November 13 2013 01:54 freelander wrote:
On November 13 2013 01:40 pedrlz wrote:
I'm learning Clojure since the only lang I knew before was Lisp (just a little), but it is hard for me to practice.

But there isn't a lot of exercises available and all I try to do seems too complex for what I can do.

What todo, should I just read books? It is a little boring, looks like that I'm not learning a lot and I forget easily. I started to get codes from the internet and trying to break down to understand what is happening, isn't the fastest way neither the easiest, but is a little more action

Also, I'm learning just for fun, that is way I'm trying Clojure (syntax from non-lisp scares me)


that's quite a unique way to get started lol

Well, I started with Lisp but then I learned about Clojure that can use Java Libraries and I thought that could be easier/more useful.

But I'm just shooting in the dark
welp


You mentioned that what you try to do seems too complex. Thats your first place to start.

Think about why it's too complex, then figure out a way to overcome that by splitting the task into more managable functions. Are those too complex? Repeat the process.

Books are a great resource if you're stuck, but reading other people's code is probably the fastest way to learn.
Any sufficiently advanced technology is indistinguishable from magic
Arnstein
Profile Blog Joined May 2010
Norway3381 Posts
November 12 2013 21:28 GMT
#7816
+ Show Spoiler +

#include <stdio.h>

int main()
{
int array[10][10];
int i;
int j;
int count;
for ( i; i<10; ++i )
{
for ( j = 0; j<10; ++j )
{
array[i][j] = count;
count++;
}
}
for ( i; i<10; ++i )
{
for ( j = 0; j<10; ++j )
{
printf( "%d", array[i][j] );
}
printf("\n");

}
}


I'm refreshing my C/C++ skills, and I don't understand why that doesn't print? Anyone know?
rsol in response to the dragoon voice being heard in SCII: dragoon ai reaches new lows: wanders into wrong game
misirlou
Profile Joined June 2010
Portugal3241 Posts
November 12 2013 21:32 GMT
#7817
On November 13 2013 06:28 Arnstein wrote:
+ Show Spoiler +

#include <stdio.h>

int main()
{
int array[10][10];
int i;
int j;
int count;
for ( i; i<10; ++i )
{
for ( j = 0; j<10; ++j )
{
array[i][j] = count;
count++;
}
}
for ( i; i<10; ++i )
{
for ( j = 0; j<10; ++j )
{
printf( "%d", array[i][j] );
}
printf("\n");

}
}


I'm refreshing my C/C++ skills, and I don't understand why that doesn't print? Anyone know?

i isn't initialized in both loops. Even assuming it gets defaulted to a value less than 10 in the first one, it enters the second one with value 10 so it never computes
Arnstein
Profile Blog Joined May 2010
Norway3381 Posts
November 12 2013 21:36 GMT
#7818
Oh, of course! Added i = 0 and j = 0 between the loops now, and now it works. Thanks!
rsol in response to the dragoon voice being heard in SCII: dragoon ai reaches new lows: wanders into wrong game
misirlou
Profile Joined June 2010
Portugal3241 Posts
Last Edited: 2013-11-12 21:56:30
November 12 2013 21:40 GMT
#7819
On November 13 2013 06:36 Arnstein wrote:
Oh, of course! Added i = 0 and j = 0 between the loops now, and now it works. Thanks!

j=0 between the outer fors (the i for's) won't acomplish what you want because j comes out of the first i iteration with value 10, and if you don't reset it, it stays 10 (which you do reset on the j=0; part of the for) and it would just print the first row.
Also dont forget to set i=0 before the first for.
You're welcome

The j=0 next to the i=0 isn't really accomplishing anything, because atm it will assign it 0 again when it enters the loop. If you do get a habbit of setting the variables like that and happen to forget j=0 inside the i loop, it will only print the first row. Also, you're not setting i=0 before the first loop. Depending on compilers, systems and randomness, your program will not work because i will have a random value.
Arnstein
Profile Blog Joined May 2010
Norway3381 Posts
Last Edited: 2013-11-12 21:50:26
November 12 2013 21:44 GMT
#7820
I did like this, and it works fine now:
+ Show Spoiler +


#include <stdio.h>

int main()
{
int array[10][10];
int i;
int j;
int count;
for ( i; i<10; ++i )
{
for ( j = 0; j<10; ++j )
{
array[i][j] = count;
count++;
}
}
i = 0;
j = 0;
for ( i; i<10; ++i )
{
for ( j = 0; j<10; ++j )
{
printf( "%d", array[i][j] );
printf( " " );
}
printf("\n");

}
}


rsol in response to the dragoon voice being heard in SCII: dragoon ai reaches new lows: wanders into wrong game
Prev 1 389 390 391 392 393 1032 Next
Please log in or register to reply.
Live Events Refresh
PiGosaur Monday
01:00
#60
PiGStarcraft589
SteadfastSC137
CranKy Ducklings93
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
PiGStarcraft589
RuFF_SC2 169
SteadfastSC 137
Nathanias 78
StarCraft: Brood War
PianO 281
Noble 50
Icarus 8
Dota 2
monkeys_forever491
League of Legends
JimRising 687
Counter-Strike
Coldzera 1503
Other Games
summit1g13503
WinterStarcraft475
C9.Mang0382
ViBE158
Organizations
Other Games
gamesdonequick1106
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 15 non-featured ]
StarCraft 2
• Hupsaiya 79
• intothetv
• AfreecaTV YouTube
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• Azhi_Dahaki22
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• Lourlo1017
• Stunt378
Other Games
• Scarra1399
Upcoming Events
Wardi Open
7h 29m
StarCraft2.fi
12h 29m
Replay Cast
19h 29m
The PondCast
1d 5h
OSC
1d 11h
Demi vs Mixu
Nicoract vs TBD
Babymarine vs MindelVK
ForJumy vs TBD
Shameless vs Percival
Replay Cast
1d 19h
Korean StarCraft League
2 days
CranKy Ducklings
3 days
SC Evo League
3 days
BSL 21
3 days
Sziky vs OyAji
Gypsy vs eOnzErG
[ Show More ]
OSC
3 days
Solar vs Creator
ByuN vs Gerald
Percival vs Babymarine
Moja vs Krystianer
EnDerr vs ForJumy
sebesdes vs Nicoract
Sparkling Tuna Cup
4 days
OSC
4 days
BSL 21
4 days
Bonyth vs StRyKeR
Tarson vs Dandy
Replay Cast
5 days
Wardi Open
5 days
StarCraft2.fi
5 days
Replay Cast
5 days
StarCraft2.fi
6 days
PiGosaur Monday
6 days
Liquipedia Results

Completed

Proleague 2025-11-30
RSL Revival: Season 3
Light HT

Ongoing

C-Race Season 1
IPSL Winter 2025-26
KCM Race Survival 2025 Season 4
YSL S2
BSL Season 21
CSCL: Masked Kings S3
Slon Tour Season 2
Acropolis #4 - TS3
META Madness #9
SL Budapest Major 2025
ESL Impact League Season 8
BLAST Rivals Fall 2025
IEM Chengdu 2025
PGL Masters Bucharest 2025
Thunderpick World Champ.
CS Asia Championships 2025
ESL Pro League S22
StarSeries Fall 2025
FISSURE Playground #2

Upcoming

BSL 21 Non-Korean Championship
Acropolis #4
IPSL Spring 2026
Bellum Gens Elite Stara Zagora 2026
HSC XXVIII
RSL Offline Finals
WardiTV 2025
Kuram Kup
PGL Cluj-Napoca 2026
IEM Kraków 2026
BLAST Bounty Winter 2026
BLAST Bounty Winter Qual
eXTREMESLAND 2025
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2025 TLnet. All Rights Reserved.