If sentence argument contains the searchValue argument, return the index at which the searchValue starts --> ErrorAppleScript: Index of substring in stringLongest substring that appears n timesAjax request returns 200 OK, but an error event is fired instead of successlooking through a string for a substringfind not just the first index of a substring in a string - python 2.7Finding a substring within a string in CJava= arbitrary placement of if statement gives different output?Finding the 2nd occurance's index of a string and that string should be the start of the line using pythonfind the begin and end index of shortest substring in a string that match another patternFinding if a string is a substring of another in Sml without library functions

Password expiration with Password manager

A Warm Riley Riddle

Stark VS Thanos

Unexpected email from Yorkshire Bank

What does air vanishing on contact sound like?

Would "lab meat" be able to feed a much larger global population

How did Arya manage to disguise herself?

Meaning of "individuandum"

How to efficiently calculate prefix sum of frequencies of characters in a string?

What word means "to make something obsolete"?

Why debootstrap can only run as root?

Any examples of headwear for races with animal ears?

Does higher resolution in an image imply more bits per pixel?

How can I fairly adjudicate the effects of height differences on ranged attacks?

How could a planet have most of its water in the atmosphere?

Selecting a secure PIN for building access

Entropy as a function of temperature: is temperature well defined?

How do you center multiple equations that have multiple steps?

What is the word which sounds like "shtrass"?

Field Length Validation for Desktop Application which has maximum 1000 characters

Has any spacecraft ever had the ability to directly communicate with civilian air traffic control?

Applying a function to a nested list

Topological Spaces homeomorphic

Is lying to get "gardening leave" fraud?



If sentence argument contains the searchValue argument, return the index at which the searchValue starts --> Error


AppleScript: Index of substring in stringLongest substring that appears n timesAjax request returns 200 OK, but an error event is fired instead of successlooking through a string for a substringfind not just the first index of a substring in a string - python 2.7Finding a substring within a string in CJava= arbitrary placement of if statement gives different output?Finding the 2nd occurance's index of a string and that string should be the start of the line using pythonfind the begin and end index of shortest substring in a string that match another patternFinding if a string is a substring of another in Sml without library functions






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








0















I tried to solve the problem below:



My Index Of:
Define a function, myIndexOf, that accepts three arguments:



  • source (string)

  • searchValue (string)

  • startIdx (number) - optional

If the source contains the searchValue, return the index at which the searchValue starts.



If the searchValue appears more than once in the source, return the index from the first occurance of the searchValue. If the searchValue doesn't exist in the source, return -1.



If a startIdx is passed into the function, ignore any instances of the searchValue that occur before that index. If no startIdx is provided, start searching from the beginning of the source.



Do not use the built-in .indexOf string method in your answer.



I tried the following code:



function myIndexOf(source, searchValue, startIdx=0)

for (i=startIdx; i<=source.length - searchValue.length; i++)

//console.log(source[i])

let subString = source.slice(i, i+searchValue.length);

if(subString === searchValue)
return i

else
return -1




myIndexOf('twice twice', 'ice', 5);


The function should return 8 but instead it returns -1. I know the else statement is probably what's causing the error but I don't understand why the else statement can't be where it is.










share|improve this question






























    0















    I tried to solve the problem below:



    My Index Of:
    Define a function, myIndexOf, that accepts three arguments:



    • source (string)

    • searchValue (string)

    • startIdx (number) - optional

    If the source contains the searchValue, return the index at which the searchValue starts.



    If the searchValue appears more than once in the source, return the index from the first occurance of the searchValue. If the searchValue doesn't exist in the source, return -1.



    If a startIdx is passed into the function, ignore any instances of the searchValue that occur before that index. If no startIdx is provided, start searching from the beginning of the source.



    Do not use the built-in .indexOf string method in your answer.



    I tried the following code:



    function myIndexOf(source, searchValue, startIdx=0)

    for (i=startIdx; i<=source.length - searchValue.length; i++)

    //console.log(source[i])

    let subString = source.slice(i, i+searchValue.length);

    if(subString === searchValue)
    return i

    else
    return -1




    myIndexOf('twice twice', 'ice', 5);


    The function should return 8 but instead it returns -1. I know the else statement is probably what's causing the error but I don't understand why the else statement can't be where it is.










    share|improve this question


























      0












      0








      0








      I tried to solve the problem below:



      My Index Of:
      Define a function, myIndexOf, that accepts three arguments:



      • source (string)

      • searchValue (string)

      • startIdx (number) - optional

      If the source contains the searchValue, return the index at which the searchValue starts.



      If the searchValue appears more than once in the source, return the index from the first occurance of the searchValue. If the searchValue doesn't exist in the source, return -1.



      If a startIdx is passed into the function, ignore any instances of the searchValue that occur before that index. If no startIdx is provided, start searching from the beginning of the source.



      Do not use the built-in .indexOf string method in your answer.



      I tried the following code:



      function myIndexOf(source, searchValue, startIdx=0)

      for (i=startIdx; i<=source.length - searchValue.length; i++)

      //console.log(source[i])

      let subString = source.slice(i, i+searchValue.length);

      if(subString === searchValue)
      return i

      else
      return -1




      myIndexOf('twice twice', 'ice', 5);


      The function should return 8 but instead it returns -1. I know the else statement is probably what's causing the error but I don't understand why the else statement can't be where it is.










      share|improve this question
















      I tried to solve the problem below:



      My Index Of:
      Define a function, myIndexOf, that accepts three arguments:



      • source (string)

      • searchValue (string)

      • startIdx (number) - optional

      If the source contains the searchValue, return the index at which the searchValue starts.



      If the searchValue appears more than once in the source, return the index from the first occurance of the searchValue. If the searchValue doesn't exist in the source, return -1.



      If a startIdx is passed into the function, ignore any instances of the searchValue that occur before that index. If no startIdx is provided, start searching from the beginning of the source.



      Do not use the built-in .indexOf string method in your answer.



      I tried the following code:



      function myIndexOf(source, searchValue, startIdx=0)

      for (i=startIdx; i<=source.length - searchValue.length; i++)

      //console.log(source[i])

      let subString = source.slice(i, i+searchValue.length);

      if(subString === searchValue)
      return i

      else
      return -1




      myIndexOf('twice twice', 'ice', 5);


      The function should return 8 but instead it returns -1. I know the else statement is probably what's causing the error but I don't understand why the else statement can't be where it is.







      javascript string if-statement search indexing






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Mar 22 at 20:20









      chazsolo

      5,44511234




      5,44511234










      asked Mar 22 at 20:02









      PineNuts0PineNuts0

      90731432




      90731432






















          1 Answer
          1






          active

          oldest

          votes


















          0














          The problem is that the for loop ends after the first iteration. With an else block in there the whole function ends its execution (and therefore the for loop) prematurely because, regardless of the condition being fulfilled, it returns a value.



          Try this:



          function myIndexOf(source, searchValue, startIdx=0)

          for (i=startIdx; i<=source.length - searchValue.length; i++)

          let subString = source.slice(i, i+searchValue.length);

          if(subString === searchValue)
          return i;




          return -1;




          In the function above the for loop will only stop if the searched value is found. If it's never found, the function will return -1 by default.






          share|improve this answer

























            Your Answer






            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "1"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55307050%2fif-sentence-argument-contains-the-searchvalue-argument-return-the-index-at-whic%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            0














            The problem is that the for loop ends after the first iteration. With an else block in there the whole function ends its execution (and therefore the for loop) prematurely because, regardless of the condition being fulfilled, it returns a value.



            Try this:



            function myIndexOf(source, searchValue, startIdx=0)

            for (i=startIdx; i<=source.length - searchValue.length; i++)

            let subString = source.slice(i, i+searchValue.length);

            if(subString === searchValue)
            return i;




            return -1;




            In the function above the for loop will only stop if the searched value is found. If it's never found, the function will return -1 by default.






            share|improve this answer





























              0














              The problem is that the for loop ends after the first iteration. With an else block in there the whole function ends its execution (and therefore the for loop) prematurely because, regardless of the condition being fulfilled, it returns a value.



              Try this:



              function myIndexOf(source, searchValue, startIdx=0)

              for (i=startIdx; i<=source.length - searchValue.length; i++)

              let subString = source.slice(i, i+searchValue.length);

              if(subString === searchValue)
              return i;




              return -1;




              In the function above the for loop will only stop if the searched value is found. If it's never found, the function will return -1 by default.






              share|improve this answer



























                0












                0








                0







                The problem is that the for loop ends after the first iteration. With an else block in there the whole function ends its execution (and therefore the for loop) prematurely because, regardless of the condition being fulfilled, it returns a value.



                Try this:



                function myIndexOf(source, searchValue, startIdx=0)

                for (i=startIdx; i<=source.length - searchValue.length; i++)

                let subString = source.slice(i, i+searchValue.length);

                if(subString === searchValue)
                return i;




                return -1;




                In the function above the for loop will only stop if the searched value is found. If it's never found, the function will return -1 by default.






                share|improve this answer















                The problem is that the for loop ends after the first iteration. With an else block in there the whole function ends its execution (and therefore the for loop) prematurely because, regardless of the condition being fulfilled, it returns a value.



                Try this:



                function myIndexOf(source, searchValue, startIdx=0)

                for (i=startIdx; i<=source.length - searchValue.length; i++)

                let subString = source.slice(i, i+searchValue.length);

                if(subString === searchValue)
                return i;




                return -1;




                In the function above the for loop will only stop if the searched value is found. If it's never found, the function will return -1 by default.







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Mar 22 at 20:27

























                answered Mar 22 at 20:13









                ChristophChristoph

                20125




                20125





























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55307050%2fif-sentence-argument-contains-the-searchvalue-argument-return-the-index-at-whic%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Kamusi Yaliyomo Aina za kamusi | Muundo wa kamusi | Faida za kamusi | Dhima ya picha katika kamusi | Marejeo | Tazama pia | Viungo vya nje | UrambazajiKuhusu kamusiGo-SwahiliWiki-KamusiKamusi ya Kiswahili na Kiingerezakuihariri na kuongeza habari

                    Swift 4 - func physicsWorld not invoked on collision? The Next CEO of Stack OverflowHow to call Objective-C code from Swift#ifdef replacement in the Swift language@selector() in Swift?#pragma mark in Swift?Swift for loop: for index, element in array?dispatch_after - GCD in Swift?Swift Beta performance: sorting arraysSplit a String into an array in Swift?The use of Swift 3 @objc inference in Swift 4 mode is deprecated?How to optimize UITableViewCell, because my UITableView lags

                    Access current req object everywhere in Node.js ExpressWhy are global variables considered bad practice? (node.js)Using req & res across functionsHow do I get the path to the current script with Node.js?What is Node.js' Connect, Express and “middleware”?Node.js w/ express error handling in callbackHow to access the GET parameters after “?” in Express?Modify Node.js req object parametersAccess “app” variable inside of ExpressJS/ConnectJS middleware?Node.js Express app - request objectAngular Http Module considered middleware?Session variables in ExpressJSAdd properties to the req object in expressjs with Typescript